【js】利用闭包消除回调函数启动时值已经发生变化的影响

本文通过JavaScript示例展示了如何使用闭包来解决异步编程中变量值被意外覆盖的问题。通过将变量固化在回调函数作用域内,确保了即使在异步操作完成时外部变量已改变,回调函数仍能访问到正确的原始值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在以下代码中,timeFun异步执行了一个匿名函数,当输出color的值时已经由green变成red,因此输出为red。

function timedFun(callback){
    setTimeout(callback,200);// 两百毫秒后调用callback函数
}

var color='green';

timedFun(function(){ // 执行timedFun函数,因为在两百毫秒后才启动匿名函数,导致输出时后面的color='red';已经先执行,所以输出时color=red.在异步执行时是值得注意的情况
    console.log("color="+color);
});

color='red';

 

下面代码是利用闭包将当时的color固化成匿名函数本地变量,这样再不受全局变量color值变化的影响。

function timedFun(callback){
    setTimeout(callback,200);// 两百毫秒后调用callback函数
}

var color='green';

(function(color){// 利用闭包,将此时的color(值为'green')封装到一个匿名函数中,color就成了这个匿名函数的本地变量,因此外界全局变量color发生变化时,本地变量color不受影响还是保持原值green
    timedFun(function(){ 
        console.log("color="+color);
    })
})(color);

color='red';

 

转载于:https://www.cnblogs.com/xiandedanteng/p/8872530.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值