Js: var self =this
var self = this; // 指代函数内部的执行环境,本作用域的对象。
这里给出了一个私有的self参数,使得对象对私有方法可见。因为私有方法无法被公共方法和方法所访问,要令私有方法能被公共方法访问,所以要把它们附加到对象上。
function VW(){
//self 被附加到了对象上,只对私有成员可见。
var self = this;
使用var声明的变量,每个变量的作用域都是局部的,这就意味着它们只能在它们所定义的函数内部访问。如果不使用var的话,变量的作用域就是全局的,也就是变量可以被Web页面中任何地方的所有JavaScript代码(或者在本页面所包含的任何外部JS库中)访问。
如果你有相同名字的全局变量和局部变量的话,设定变量的作用域很重要。从开始就养成良好的JavaScript编程习惯。这种习惯之一就是:显式地定义变量的作用域。
下面是一些考虑作用域时的规则:
如果函数中的变量在声明时使用了关键字var,它就只能在此函数的局部使用。
如果函数中的变量在声明时没有使用关键字var,而又存在一个同名的全局变量,它就会被当作那个全局变量。
如果变量在局部中声明并使用了关键字var,但它又没有被初始化(比如赋值),它可以访问但没有被定义。
如果变量在局部中声明,但没有使用关键字var,或显式地声明为全局变量,但它又没有被初始化,它在全局上可以访问但没有被定义。
通过在函数中使用var,你可以防止使用同名的全局变量和局部变量所造成的问题。这在使用外部JavaScript库的时候尤为关键。
_________________________________________________________________________________________
在js里 这个语法 是因为在一个对象内部,this指向的是这个对象,在普通函数内部,this指向的是window对象。所以不能在普通函数里面用this来访问对象的属性,如下:
function a(){
this.name = "hello";
function b(){ //b只是一个普通函数,不是a的属性方法
alert(this.name);
}
b(); //调用b
}
new a(); //新建一个a对象,此时alert name undefined
所有如果在一个对象里面定义了一个普通函数(不是该对象的属性函数),为了能够在该普通函数里面访问到对象的属性,可以先把对象的this赋值给一个变量self。然后再再该普通函数里通过self来获取到对象的属性。如下
function a(){
var self = this;
this.name = "hello";
function b(){ //b只是一个普通函数,不是a的属性方法
alert(self.name);
}
b(); //调用b
}
new a(); //新建一个a对象,此时alert name = hello
总结一下,如果不是为了在其他函数中访问到对象的属性,很多时候我们是不用写var self = this这句代码的。
var self = this这句代码是为了能让其他函数访问到对象的属性,因为在不同的作用域内,this的指向是不同的。