setTimeout给了我新的变量,而不是旧的
setTimeout giving me the new variable not the old
本文关键字:变量 setTimeout 更新时间:2023-09-26
所以我正在制作一个必须延迟的函数,我需要旧的值,而不是新的
test='old';
setTimeout( function(test) {alert(test)}, 1000,[test]);
test='new';
一个不依赖于setTimeout
向回调传递参数的能力的通用解决方案是使用IIFE创建一个新的作用域并捕获变量的当前值:
test='old';
(function(test) {
setTimeout(function() {
alert(test)
}, 1000);
}(test));
test='new';
这适用于任何类型的回调。另请参阅循环中的JavaScript闭包——一个简单的实用示例。
相关文章:
- Angularjs 更新 setTimeout 中的范围变量不起作用
- 被覆盖的 setTimeout 变量中的函数
- nodejs-settimeout是否在不同的循环中共享变量
- toString似乎导致setTimeout不总是为toString的变量参数执行函数
- 可以't获取具有“t”的对象变量;这个“;由setTimeout()函数调用的对象函数中的属性
- 变量在Javascript中是如何工作的?可以在setTimeout期间更改变量值
- Javascript setTimeout作用域引用了错误的变量
- 一旦超时执行,清除或重新分配分配给 setTimeout 返回值的变量是否有任何技术点
- 使用变量作为 setInterval / setTimeout 中的时间
- 如何将变量传递到 setTimeout 函数中
- 为什么这个全局计数器变量不适用于 setTimeout
- JavaScript setTimeout可以't访问函数变量
- 如何在setTimeout中维护循环变量的值?Javascript
- Angular2,视图在settimeout变量更改后未更新
- 将对象内的变量传递到setTimeout
- javascript setTimeout()输出另存为变量
- for循环中的setTimeout,变量不变
- setTimeout似乎正在更改我的变量!为什么?
- setTimeout给了我新的变量,而不是旧的
- 如何从iframe(Javascript)中撤销setTimeout变量