setTimeout(fn,0)的作用分析


众所周知,大家对setTimeout的用法肯定都比较熟悉了,但是不是还是会经常忘记使用呢,例如博主阿里面试时就忘了,见阿里前端面试

今天跟大家讨论一下setTimeout(fn,0)的用法,相信很多人没有这样使用过。js运行是基于单线程的,意味着一段代码执行时,其他代码将进入队列等待,一旦线程有空闲就执行后续代码。如果代码中设定了一个setTimeout,那么浏览器便会在合适的时间,将代码插入任务队列,如果这个时间设为 0,就代表立即插入队列,但并不是立即执行,仍然要等待前面代码执行完毕(其实有个延时,具体是16ms还是4ms取决于浏览器)。所以setTimeout并不能保证执行的时间,是否及时执行取决于 JavaScript 线程是拥挤还是空闲。

以一个例子说明,当用户在文本框里输入时,将输入的内容在下方显示出来。

未使用setTimeout函数
使用setTimeout函数

当用户按下按键的时候,JavaScript 引擎需要执行keydown的事件处理程序,然后更新文本框的value值,这两件事也需要按顺序来,事件处理程序执行时,更新value值的任务则进入队列等待。所以我们在keydown的事件处理程序里是无法得到更新后的value的,利用setTimeout,我们把取value的操作放入队列,放在更新value值以后,这样便可获取出文本框的值。

onkeyup事件也可以得到文本框的值,但一直按住时没法及时获取,只有松开时才能获取文本框的值。右键粘贴获取内容可以用html5的oninput事件,IE9之前有专有的onpropertychange事件。

1 <input type="text" value="" onkeypress="var self=this;setTimeout(function(){show(self.value)},0)"> 
2 <div></div>
3 <script>
4 document.getElementsByTagName('div')[0].innerHTML = val;
5 </script>
优质内容筛选与推荐>>
1、flex布局浅谈
2、IDA Pro 权威指南学习笔记(十三) - 基本代码转换
3、Pycharm中使用GitHub
4、JavaWeb核心编程之Tomcat安装和配置
5、HttpPost 上传文件过大时 接口返回404


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号





    联系我们

    欢迎来到TinyMind。

    关于TinyMind的内容或商务合作、网站建议,举报不良信息等均可联系我们。

    TinyMind客服邮箱:support@tinymind.net.cn