登录
首页 >  文章 >  前端

箭头函数和this

来源:dev.to

时间:2024-07-30 20:18:41 419浏览 收藏

本篇文章给大家分享《箭头函数和this》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

箭头函数和this

这个 foo.baz() 的结果会是什么??

const foo = {
  bar: 10,
  baz: () => console.log(this.bar),
};


foo.baz();

这个函数看起来应该可以工作,但是如果你运行它,结果将是“未定义”。为什么这样?
在 javascript 中,当你使用箭头函数时,函数 console.log(this.bar) 会查找全局变量,因为“this”关键字并不绑定到周围的对象,而是绑定到浏览器或浏览器中的全局对象(窗口)。 node.js 环境。
为了解决这个问题,我们要么使用 foo.bar 要么稍微改变一下代码并使用正则函数表达式,如下所示

 baz: function () {
    console.log(this.bar);
  },

或者,如果我们必须使用箭头函数,我们可以使用对象名称并像这样调用 foo.bar ,而不是调用局部变量 this.bar 。

 baz: () => console.log(foo.bar),

现在输出将正确为 10。

以上就是《箭头函数和this》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>