关于js this指向的理解

var obj = {
    count : 1,
    add : function(a) {
         var f = v => v + this.count
    return f(a);
  }, 
  add1 : function(a) {
       var b = {
           count : 2
        };
       var f = v => v + this.count;
    return f.call(b,a);
  },

  add2: function(a) {
       var b = {
          count: 2
       };
       var f = function(v){return v + this.count};        
    return f.call(b,a);
  }
};
console.log(obj.add(1));  //2    
console.log(obj.add1(1)); //2
console.log(obj.add2(1)); //3

总结:
        哪个对象调用了函数,该函数里面的this就指向谁!如果一个函数没有明确的调用者,则this就默认指向window对象,箭头函数比较特殊,箭头函数没有this,箭头函数里面的this继承外面的环境!即箭头函数外面环境的this指向谁,箭头函数的this就指向谁。
要更全面了解,可以参考以下文章:https://www.cnblogs.com/zjjDaily/p/9482958.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值