zoukankan      html  css  js  c++  java
  • 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>
  • 相关阅读:
    java常用容器简要性能分析(List。Map。Set)
    初始化 List 的五种方法(java)【转】
    线程池方式对数组多线程随机取出分析
    Spring文件下载方式整理
    阿里云linux安装Consul启动
    Java字节流&字符流的转换
    VUE中字符串实现JSON格式化展示。
    java中URL作为参数前后端传递分析
    Java实现GBK转码到UTF-8(文件)
    python处理Excel文件
  • 原文地址:https://www.cnblogs.com/soulcm/p/3998199.html
Copyright © 2011-2022 走看看