简要咨询咨询QQ网站导航网站搜索手机站点联系我们设为首页加入收藏 

Javascript的setTimeout()使用闭包特性时需要注意的问题

来源:易贤网   阅读:899 次  日期:2014-10-15 15:21:35

温馨提示:易贤网小编为您整理了“Javascript的setTimeout()使用闭包特性时需要注意的问题”,方便广大网友查阅!

setTimeout经常被用于延迟执行某个函数,用法为:

代码如下:

setTimeout(function(){

}, timeout);

有时为了进行异步处理,而使用setTimeout(function…,0);比如:

代码如下:

function f(){

… // get ready

setTimeout(function(){

…. // do something

}, 0);

return …;

}

在setTimeout设定的函数处理器之前,函数f返回;

在使用异步处理时,尤其是使用闭包特性时,要特别小心;

例如:

代码如下:

for(var i = 0 ; i < 10; i++){

setTimeout(function(){

console.log(i);

}, 0);

}

对于初次使用这种方式的同学来说,很可能会认为程序会打印0…9,可结果确实打印10个10;

问题就在于,当循环完成时,function得到执行,而i已经变成10,console.log(i)中使用的是10!

加入你的目的是打印0…9,那么可以换一种方式,用函数参数来保存0….9(其实也是利用了闭包):

代码如下:

for(var i = 0 ; i < 10; i++){

setTimeout((function(i){

return function(){

console.log(i);

}

})(i), 0);

}

更多信息请查看IT技术专栏

更多信息请查看脚本栏目
点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】     【点此处查询各地各类考试咨询QQ号码及交流群
上一篇:常用的jquery模板插件
下一篇:一个JavaScript处理textarea中的字符成每一行实例
易贤网手机网站地址:Javascript的setTimeout()使用闭包特性时需要注意的问题
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!