为了账号安全,请及时绑定邮箱和手机立即绑定

关于js中this的指向

标签:
JavaScript

js中this的指向是在运行时会变动的

这句话严谨的说是有问题的。

this这个关键词,在java中的解释是引用当前类的实例变量。这里有两个关键词当前类实例变量,说白了this当前执行方法的调用者

比如

const a = {
  say() {
    console.log(this === a);
  }
}

a.say(); // true

再比如

class A {

  constructor() {
    this.name = "A";
  }

  say() {
    console.log(this.name);
  }
}

const a = new A();

a.say(); // "A"

const b = {
  name: "B",
  say: a.say
}

b.say(); // "B"

但有时,我们会遇到下面👇的情况

function sayThis() {
  // TODO
  console.log(this);
}

sayThis();

一个方法,没有直接调用者。。。。

这种情况的时候,代码的效果就是这样的

function sayThis() {
  // TODO
  console.log(this);
}
this.sayThis();

如果一个函数没有显式的调用者,那么,这个函数的调用者就是此函数执行的作用域中的this

所以,归根结底,this当前执行方法的调用者

🎉

🎉

🎉

🎉

🎉

🎉

🎉

你以为这样就结束了?Too young too simple

js中还有三个显式绑定this的方法,bindapplycall当使用这些方法指定执行函数的this时,那this基本上就是指定的了

基本上?有特殊情况吗?

有!!!!😂

箭头函数

const sayThis = () => {
    console.log(this)
}

上面的代码用babel编译之后

var _this = this;
var sayThis = function () {
    console.log(_this);
};

很容易理解箭头函数中this的指向

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消