JavaScript的this简单实用

1、默认绑定全局变量,在全局函数中:

function fn(){
  console.log(this.a);      
}
var a=2;
fn();//这里调用的是window

2、隐式绑定:

function fn(){
   console.log(this.a);
}
var obj={
   a:2,
   fn:fn 
};
obj.fn();//这里隐式的调用了obj对象,这里绑定了obj对象

这里要说明的是让函数传递引用,致使this绑定的上下文改变。则this的失去隐式绑定:

function fn(){
  console.log(this.a);
}
var obj={
  a:2,
  fn:fn
};
var bar = obj.fn;
var a = "wocao";
bar();//wocao

3、显示绑定,利用apply,call,bind:

function fn(){
  console.log(this.a);
}
var obj={
  a:2
};
fn.call(obj);//不传则为全局变量

4、new构造对象:

function fn(a){
  console.log(this.a);
}
var bar = new fn(2);
console.log(bar.a);//这里注意bar并不是一个函数,只是一个被赋值的变量对象

 5、eval函数中this指向:

function fn(){
       eval("console.log(this.a)");
    }
    var obj = {
      a:3,
      fn:fn
    };
    var a = 0;
    obj.fn();//3,当前函数执行的作用域
上面的代码有点挫,换了一个
var name = "window";

var Bob = {
    name: "Bob",
    showName: function(){
        eval("alert(this.name)");
    }
};

Bob.showName();    //Bob
var name = "window";

var Bob = {
    name: "Bob",
    showName: function(){
        alert(this.name);
    }
};

Bob.showName();    //Bob,其实就是没影响啦
 
  

 

 
 

6、setTimeout,setInterval都会把对象变成全局,两个因为是异步执行的

转载于:https://www.cnblogs.com/thecatshidog/p/5014425.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值