重温前端之this指向问题

默认绑定

function foo() {
  console.log(this.a);
}
var a = 1;
foo(); // 2

隐式绑定

function foo() {
  console.log(this.a);
}
var obj = {
  a: 2,
  foo: foo,
};
obj.foo(); // 2

隐式丢失问题

在我的理解中,函数传递时,只传递了函数本身,而不传递其上下文,所以造成了丢失

function foo() {
  console.log(this.a);
}
var obj = {
  a: 2,
  foo: foo,
};
var bar = obj.foo; // 函数别名!
var a = "oops, global"; // a 是全局对象的属性
bar(); // "oops, global"

显示绑定

直接把对象绑定到函数上,强行获得上下文

function foo() {
  console.log(this.a);
}
var obj = {
  a: 2,
};
foo.call(obj); // 2

硬绑定

硬绑定的对象无法再修改 this

function foo() {
  console.log(this.a);
}
var obj = {
  a: 2,
};
var bar = function () {
  foo.call(obj);
};
bar(); // 2
// 硬绑定的 bar 不可能再修改它的 this
bar.call(window); // 2

new 绑定

  1. 创建一个空对象
  2. 将其原型指向构造函数
  3. 绑定构造函数的 this
  4. 返回 new 的对象

优先级

new > 显示绑定 > 隐式绑定 > 默认绑定

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值