Javascript的setTimeout()使用闭包特性时需要注意的问题
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Javascript的setTimeout()使用闭包特性时需要注意的问题,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含993字,纯文字阅读大概需要2分钟。
内容图文
这篇文章主要介绍了Javascript的setTimeout(0)使用闭包特性时需要注意的问题,需要的朋友可以参考下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); }
更多Javascript的setTimeout()使用闭包特性时需要注意的问题相关文章请关注PHP中文网!
内容总结
以上是互联网集市为您收集整理的Javascript的setTimeout()使用闭包特性时需要注意的问题全部内容,希望文章能够帮你解决Javascript的setTimeout()使用闭包特性时需要注意的问题所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。