认识延迟时间为 0 的 setTimeout

作者:realazy 来源:realazy博客 时间:2008-04-04 16:37:00 

由 John Resig 的 How JavaScript Timers Work 可以知道,现有的 JavaScript 引擎是单线程处理任务的。它把任务放到队列中,不会同步去执行,必须在完成一个任务后才开始另外一个任务。

让我们看看我之前的文章:JavaScript的9个陷阱及评点,在第 9 点 Focus Pocus 中提到的问题。原作者对这个认识有所偏差,其实不只是 IE 的问题,而是现有 JavaScript 引擎对于线程实现的问题(关于线程,我的概念其实不多,如果不对,希望读者多多指教)。

我们通过一个例子来说明,请访问 settimeout.html.

我们来看 1 和 2。如果你能看看源代码,会发现我们的任务很简单,就是给文档增加一个 input 文本框,并聚焦和选中。请现在分别点击一下,可以看到,1 并没有能够聚焦和选中,而 2 可以。它们之间的区别在于,在执行

input.focus();
input.select();

时, 2 多了一个延迟时间为 0 的 setTimeout 的外围函数,即:

setTimeout(function(){
 input.focus();
 input.select();
}, 0);

按照 JavaScript: The Definitive Guide 5th 的 14.1 所说:

在实践中,setTimeout 会在其完成当前任何延宕事件的事件处理器的执行,以及完成文档当前状态更新后,告诉浏览器去启用 setTimeout 内注册的函数。

其实,这是一个把需要执行的任务从队列中跳脱的技巧。回到前面的例子,JavaScript 引擎在执行 onkeypress 时,由于没有多线程的同步执行,不可能同时去处理刚创建元素的 focusselect 事件,由于这两个事件都不在队列中,在完成 onkeypress 后,JavaScript 引擎已经丢弃了这两个事件,正如你看到的例子 1 的情况。而在例子 2 中,由于setTimeout可以把任务从某个队列中跳脱成为新队列,因而能够得到期望的结果。

这才是延迟事件为 0 的setTimeout的真正目的。在此,你可以看看例子 3,它的任务是实时更新输入的文本,现在请试试,你会发现预览区域总是落后一拍,比如你输 a, 预览区并没有出现 a, 在紧接输入 b 时, a 才不慌不忙地出现。其实我们是有办法让预览区跟输入框同步地,在此我没有给出答案,因为上面所说的,就是解决思路,try it yourself!

标签:settimeout,延迟,JavaScript
0
投稿

猜你喜欢

  • 关于select元素的两个小问题

    2008-12-25 13:41:00
  • JavaScript的replace方法与正则表达式结合应用讲解

    2008-03-06 21:37:00
  • 数据库安全管理的三个经验分享

    2009-04-01 15:49:00
  • 用图片做网站输入验证的构想

    2009-02-02 10:18:00
  • ASP.NET 2.0中Gridview控件高级技巧图文教程

    2007-08-07 15:46:00
  • 垂直无缝滚动图片(兼容性好)实例教程源码下载

    2010-04-06 12:16:00
  • 深入透析样式表滤镜(下)

    2011-06-14 09:49:19
  • 求英文字母或数字或下划线或汉字的js正则表达式

    2009-08-04 17:59:00
  • 这些CSS Selector,你都熟悉吗?

    2008-12-21 16:30:00
  • 如何往SQL Server数据库传递日期数据?

    2010-06-08 09:29:00
  • asp如何随机显示网站链接?

    2010-06-07 20:40:00
  • asp如何显示全部的环境变量?

    2010-06-08 09:34:00
  • SQL Server树型结构数据处理的存储过程

    2010-01-26 13:40:00
  • asp中判断服务器是否安装了某种组件的函数

    2011-02-16 10:53:00
  • ASP实现SQL语句日期格式的加减运算

    2008-11-07 15:13:00
  • MYSQL 数据库同步

    2008-11-24 12:39:00
  • 多维度导航探秘II

    2010-08-17 21:24:00
  • asp清空站点缓存

    2009-08-04 18:01:00
  • 让ASP组件来保护你的网站,自定义加密方法的使用

    2009-11-07 19:27:00
  • html元素input使用方法

    2007-12-06 13:02:00
  • asp之家 网络编程 m.aspxhome.com