this 指向问题

  1. 当以函数的形式调用时,this是window
  2. 当以方法的形式调用时,谁调用方法this就是谁
  3. 当以构造函数的形式调用时,this就是新创建的那个对象   

当您以函数的形式调用时,this指向全局对象,在浏览器环境下通常是window对象。例如:

function hello() {
  console.log(this); 
}

hello();  // 输出: Window 对象

当您以方法的形式调用时,this指向调用该方法的对象。例如:

const obj = {
  name: 'Alice',
  sayHello: function() {
    console.log(this.name);
  }
};

obj.sayHello();  // 输出: Alice

 当您以构造函数的形式调用时,this指向新创建的对象。例如:

function Person(name) {
  this.name = name;
}

const person1 = new Person('Bob');
console.log(person1.name);  // 输出: Bob

const person2 = new Person('Charlie');
console.log(person2.name);  // 输出: Charlie

在上面的例子中,当我们使用 ​new Person('Bob')​来创建person1对象时,this指向了person1对象,并且将name属性设置为'Bob'。同样,当我们使用 ​new Person('Charlie')​来创建person2对象时,this指向了person2对象,并且将name属性设置为'Charlie'。

总结来说,this关键字的指向根据不同的使用方式而有所不同。在函数调用时,它指向全局对象;在方法调用时,它指向调用该方法的对象;在构造函数调用时,它指向新创建的对象。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值