js this指向问题

发布于 2022-09-13 00:08:09 字数 335 浏览 16 评论 0

class Test {
            constructor(fn) {
                fn(this._resolve);
            }
            _resolve(value) {
                console.log(this);
            }
        }
        let p = new Test(function (resolve) {
            resolve('5秒');
      })

为什么输出this输出为 undefined 运行环境不能是undefined吧

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

听风吹 2022-09-20 00:08:09

js里的this一般分为四种情况
1.在全局环境下调用,如foo(),this指向window,严格模式下为undefinded
2.被对象调用,如a.foo(),this指向a
3.通过call,apply,bind等函数强制绑定this
4.var foo=new function Foo();这个时候this指向foo,即Foo()构造出来的对象。
如果能帮助到你,我也很高兴。
ps:我说的仅作为参考,不是金科玉律。

疯到世界奔溃 2022-09-20 00:08:09

fn(this._resolve);是把this._resolve当做一个函数传递进去,这个效果和下面代码类似

var obj = {
  fn: function(){console.log(this)}
}
var f = obj.fn
f()

运行时,函数里的this是无主的,运行环境下看环境打印undefined、window或报错

这里你需要传进去的时候使用bind绑定下就可以了

constructor(fn) {
   fn(this._resolve.bind(this));
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文