众所周知,大家对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事件。

 <input type="text" value="" onkeypress="var self=this;setTimeout(function(){show(self.value)},0)">
<div></div>
<script>
document.getElementsByTagName('div')[0].innerHTML = val;
</script>

最新文章

  1. 小程序de 一些经验1
  2. 你不可不知的HTML优化技巧
  3. 由一个异常开始思考springmvc参数解析
  4. SPOJ BALNUM
  5. Bootstrap页面布局8 - BS常用标签与样式
  6. UVALive 7281 Saint John Festival (凸包+O(logn)判断点在凸多边形内)
  7. Ehcache和MemCached比较分析
  8. 通过代码设置button中文字的对齐方式
  9. (原)不明白JNI指针调用顺序
  10. 控制台console使用MFC库函数,Cout输出CString的方法
  11. 多表查询 INNER JOIN ON WHERE
  12. OC学习10——内存管理
  13. 空间金字塔池化(Spatial Pyramid Pooling, SPP)原理和代码实现(Pytorch)
  14. LoadRunner(三)——LR相关概念&amp;组成部分
  15. 网络库压力测试:mongols VS evpp
  16. springbootAdmin+eureka集群+swagger
  17. Codeforces 837E Vasya&#39;s Function - 数论
  18. sublime格式化js、css、html的通用插件-html js css pretty
  19. Eclipse技巧
  20. vs2017 xamarin新建单独UWP类库提示不兼容

热门文章

  1. luogu2763 试题库问题 二分匹配
  2. B1821 [JSOI2010]Group 部落划分 Group 二分答案&amp;&amp;并查集
  3. .sh文件 编写格式
  4. for 循环的中的i
  5. 【Codeforces】Codeforces Round #373 (Div. 2)
  6. 取消VS2017窗口置顶
  7. CSS的常用属性(二)
  8. android黑科技系列——Android中新型安全防护策略
  9. 酷派 5267 刷入第三方 recovery教程 刷机 ROOT
  10. 黑客常用dos命令