js老生常谈 的this指向问题

        在js中this的指向对于新手来说一定是个难题,但是如果你真正理解了的话,也就没什么问题啦,下面就来讲讲this吧。

JS中,this的值取决于调用的模式(调用对象),而JS中共有4种调用模式:

1.函数调用模式

当一个函数不是一个对象的属性时,当作函数俩调用,这时函数内的this指向全局对象(大对数情况下是window)

  

window.dragon=1;
function getDragon(){
 console.log(this.dragon);
}
getDragon();//输出1,此时的this指向window

2.方法调用模式

     当一个函数是一个对象的属性时,我们称它为该对象的一个方法,当一个方法被调用时,this指向该对象。

   该模式中,this对象的绑定发生在方法被调用时

var obj={
  dragon:2,
  getDragon:function(){
       console.log(this.dragon);//输出2,this指向Obj
  }   
}
obj.getDragon();

3.构造器调用模式

使用new调用的函数称为构造器函数,此时this的指向是该构造器函数实例出来的对象。

function main(val){
  this.dragon=val;
}
main.prototype.getDragon=function(){
  console.log(this.dragon);
}
 
var fun=new main(3);
fun.getDragon();
fun.dragon;//输出3,this指向main的实例对象fun

4.apply/call调用模式以及bind

apply、call、bind方法可以让我们设定调用者中的this指向谁

function showDragon(){
  console.log(this.dragon);
}
var obj={
  dragon:4
}
showDragon.call(obj)//输出4,this指向了obj对象

ES5中bind方法,具体用法可以google一下,这里是演示this绑定的用法:

function showDragon(){
  console.log(this.dragon);
}
var obj={
  dragon:4
}
var showDragon2=showDragon.bind(obj);
showDragon2()//输出4,this指向了obj对象

bind有很多种用法,可以自己去查阅一下哦

以上这篇老生常谈 js中this的指向就是小编分享给大家的全部内容了,有什么不足可以批评指正。。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值