javascript之var self = this

在js代码中,经常可以看到有如下的一个语句:

var self = this;

之所以写这个语句,是因为在一个对象内部,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

同时,在对象内部定义的匿名函数的this指针也是指向window对象,而不是该对象,看如下例子:

var param = "hello";
var myObject = {
  param: 123,
  method: function(){
    alert( this.param );  //this指向myObject
  },
  method2: function(){
    setTimeout(function(){  //匿名函数
      alert( this.param ); //this指向windows
    },100);
  }
}
myObject.method(); //alert 123
myObject.method2();  //alert hello

总结一下,如果不是为了在其他函数中访问到对象的属性,很多时候我们是不用写var self = this这句代码的。
var self = this这句代码是为了能让其他函数访问到对象的属性,因为在不同的作用域内,this的指向是不同的。

如果对this指针的指向不是很明白的,可以看我的这篇文章:http://blog.csdn.net/liujan511536/article/details/50233097

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值