温馨提示×

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

小云
142
2023-09-26 06:04:43
栏目: 编程语言

在类方法中,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方法也不行。

0