使用promises时,为什么this在类方法中未定义

avatar
作者
猴君
阅读量:8

在类方法中,this的值取决于方法的调用方式。当使用普通函数调用类方法时,this会指向调用该方法的对象。但是,当使用箭头函数调用类方法时,this会继承自外部作用域,并且不会被绑定到类的实例上。这是因为箭头函数没有自己的上下文,它继承了其父级上下文的this值。

在使用Promises时,如果你将类方法作为回调函数传递给Promise的then方法时,它会被作为普通函数调用,而不是作为方法调用。因此,this会指向全局对象(在浏览器环境中通常是window对象)或者undefined(在严格模式下)。

为了在类方法中正确使用this,可以使用箭头函数来定义类方法。这样,this会继承自外部作用域,并且会正确地指向类的实例。例如:

class MyClass { myMethod() { return new Promise((resolve, reject) => { // 在这里可以正常访问this resolve(this.someData); }); } } 

在使用箭头函数定义类方法时,需要注意以下几点:

  1. 箭头函数不能用作构造函数,因此不能使用new关键字创建类的实例。

  2. 箭头函数没有自己的arguments对象,也不能使用super关键字来访问父类的方法。

  3. 箭头函数不能改变自己的this值,即使使用callapplybind方法也不行。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!