16、JavaScript 中的上下文问题解决与异步数据获取

JavaScript 中的上下文问题解决与异步数据获取

1. 用 bind() 解决上下文问题

在 JavaScript 编程中,上下文问题是一个常见的挑战,特别是在使用 this 关键字时。函数创建新上下文可能会导致意外结果,尤其是在回调或数组方法中使用 this 时,这种问题在类中也依然存在。

1.1 上下文问题示例

以一个验证器为例,最初它是一个对象字面量,现在将其转换为类:

class Validator {
    constructor() {
        this.message = 'is invalid.';
    }
    setInvalidMessage(field) {
        return `${field} ${this.message}`;
    }
    setInvalidMessages(...fields) {
        return fields.map(this.setInvalidMessage);
    }
}

当调用 setInvalidMessages() 时, map() 方法调用 setInvalidMessage() 会创建一个新的 this 绑定,导致上下文问题,可能会出现 TypeError: Cannot read property 'message' of undef

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值