this的使用

1.call
 var obj={name:"4"};
 var fn1=function(){console.log(this)};
   function fn2(){console.log(this)};
  fn1.call(obj) 
=>Object {name: "4"}
  fn2.call(obj) 
=>Object {name: "4"} 
2.
var myObject = {
    na:"bar",
    func: function() {
             var self = this;
            console.log(" " + this.na);

           (function (){
             console.log("inner func: this.na= " + this.na);
             console.log("inner func: self.na= " + self.na);
      }());
   }
};
na="window na";
myObject.func();


=> bar
=> inner func: this.na= window na
=> inner func: self.na= bar
-------------------------------------------
var o={
       m:function(){
            var that=this;
           console.log(that);
           a();
           function a(){
               console.log(this)
           }
    }
}

o.m();
=>Object {}
=>Window {external: Object, chrome: Object, document: document, user_data: Object, is_option: false…}
this上下文只存在两种语义:
一种是被当作方法调用,this指向调用它的对象,(比如上面的that);一种是作为函数调用,指向Global对象,它没有作用域的限制,a由于是作为函数被调用,所以它指向window。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值