javascript中关键字this的学习心得

    javaScript中的this关键字不是很难理解,但却非常重要。要掌握好this,最重要的就是记清楚一句话:this总是出现在对象的方法中,并且总是指向调用这个方法的那个对象。先看下面这个例子。

  

在浏览器中运行这段代码,会弹出对话框,显示“john”,说明程序在运行到alert(this.name)的时候,this指向的是调用此方法的person对象。

 

再看一个例子。

 


 上面的代码先创建了函数showName,然后又创建了两个对象person1和person2,其中person1的name属性为"john",person2的name属性为"mike"。这两个对象又都被赋予了getName属性,并指向同一个function即showName。

调用每个对象的getName方法,person1输出为"john",person2输出为"mike"。这是因为person1调用getName时,alert(this.name) 这句代码中的this 指向了person1对象。而person2调用getName时,this又指向了person2。

 

注意,引用对象的属性时,必须使用this关键字。例如下面的代码

这段代码不能正常运行,因为在函数中没有使用this来引用对象的属性,所以当程序运行时,就会将age当成局部变量或是全局变量,然后该函数将查找局部变量或者是全局变量,但是此变量却并没有定义过。 

      关于this,还有一个特性应该注意。考虑下面的代码 。

 

这段代码会输出结果"12",这是因为在基于浏览器的javaScript中,所有属于全局作用域的变量其实都是window对象的属性,所以上面的代码其实和下面的代码是相等的。

 

由此我们可以看出,即使在全局作用域下调用某方法,this也是始终指向调用它所在方法的那个对象的。

      所以,要理解javaScript中的this,只要牢记一句话,this必须使用在一个方法(函数)中,并且在运行时哪个对象调用了这个方法,this就指向那个对象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值