当我们遇到错误的"this"上下文时,我们需要根据具体的情况来决定替换的内容。以下是几种常见的替换方式:
const obj = {
name: 'John',
sayHello: function() {
const innerFunc = () => {
console.log(`Hello, ${this.name}!`);
};
innerFunc();
}
};
obj.sayHello(); // Output: Hello, John!
const obj1 = {
name: 'John',
sayHello: function() {
function innerFunc() {
console.log(`Hello, ${this.name}!`);
}
const boundFunc = innerFunc.bind(obj1);
boundFunc();
}
};
obj1.sayHello(); // Output: Hello, John!
const obj2 = {
name: 'John',
sayHello: function() {
function innerFunc() {
console.log(`Hello, ${this.name}!`);
}
innerFunc.call(obj2);
}
};
obj2.sayHello(); // Output: Hello, John!
以上是几种常见的替换错误的"this"上下文的方式。根据具体情况选择合适的方法来解决问题。
领取专属 10元无门槛券
手把手带您无忧上云