经常看到setTimeout延时0ms的javascript代码,感到很迷惑,难道延时0ms和不延时不是一个道理吗?后来通过查资料以及实验得出以下两个作用,可能还有作用我还不知道,希望得知的朋友在后面评论上不吝指出。
1、实现javascript的异步;
正常情况下javascript都是按照顺序执行的。但是我们可能让该语句后面的语句执行完再执行本身,这时就可以用到setTimeout延时0ms来实现了。
如:
alert(1);
setTimeout("alert(2)", 0);
alert(3);
虽然延时了0ms,但是执行顺序为:1,3,2
这样就保证setTimeout里面的语句在某一代码段中最后执行。
2、在事件中,setTimeout 会在其完成当前任何延宕事件的事件处理器的执行,以及完成文档当前状态更新后,告诉浏览器去启用 setTimeout 内注册的函数。;
举个例子来说这句话的意思,假如当某个事件在页面上建立一个文本框,并给文本框赋值(完成文档当前状态更新),然后将焦点定到文本框,并且选中文本框的内容(后面部分就需要用到setTimeout 延迟0ms实现,否则不好实现)。
先看个例子:
2<html>
3<head>
4<title>setTimeout</title>
5<script type="text/javascript" >
6 (function(){
7
8 function get(id){
9 return document.getElementById(id);
10 }
11
12 window.onload = function(){
13 get('makeinput').onmousedown = function(){
14 var input = document.createElement('input');
15 input.setAttribute('type', 'text');
16 input.setAttribute('value', 'test1');
17 get('inpwrapper').appendChild(input);
18 input.focus();
19 input.select();
20 }
21 get('makeinput2').onmousedown = function(){
22 var input = document.createElement('input');
23 input.setAttribute('type', 'text');
24 input.setAttribute('value', 'test1');
25 get('inpwrapper2').appendChild(input);
26 setTimeout(function(){
27 input.focus();
28 input.select();
29 }, 0);
30 }
31 get('input1').onkeypress = function(){
32 get('preview1').innerHTML = this.value;
33 }
34 get('input2').onkeypress = function(){
35 setTimeout(function(){
36 get('preview2').innerHTML = get('input2').value;
37 },0 );
38 }
39 }
40 })();
41</script>
42</head>
43<body>
44 <h1><code>DEMO1</code></h1>
45 <h2>1、未使用 <code>setTimeout</code>(未选中文本框内容)</h2>
46 <button id="makeinput">生成 input</button>
47 <p id="inpwrapper"></p>
48 <h2>2、使用 <code>setTimeout</code>(立即选中文本框内容)</h2>
49 <button id="makeinput2">生成 input</button></h2>
50 <p id="inpwrapper2"></p>
51
52--------------------------------------------------------------------------
53 <h1><code>DEMO2</code></h1>
54 <h2>1、未使用 <code>setTimeout</code>(只有输入第二个字符时,前一个字符才显示出来)</h2>
55 <input type="text" id="input1" value=""/><div id="preview1"></div>
56 <h2>2、使用 <code>setTimeout</code>(输入时,字符同时显示出来)</h2>
57<input type="text" id="input2" value=""/><div id="preview2"></div>
58</body>
59</html>
60
61
运行示例
现有的 JavaScript 引擎是单线程处理任务的。它把任务放到队列中,不会同步去执行,必须在完成一个任务后才开始另外一个任务。其实,这是一个把需要执行的任务从队列中跳脱的技巧。在DEMO1中,JavaScript 引擎在执行 onmousedown时,由于没有多线程的同步执行,不可能同时去处理刚创建元素的 focus 和 select 方法,由于这两个方法都不在队列中,在完成 onmousedown 后,JavaScript 引擎已经丢弃了这两个任务,正如第一种情况。而在第二种情况中,由于setTimeout可以把任务从某个队列中跳脱成为新队列,因而能够得到期望的结果。
相关推荐
然而,当我们将`setTimeout`的延时时间设置为0毫秒时,它的作用可能并不像表面上看起来那么简单。在深入解释这个现象之前,我们需要先了解JavaScript的执行环境——单线程和事件循环机制。 JavaScript引擎本质上是...
在实际应用中,应优先考虑使用`setTimeout()`或`setInterval()`这样的标准API,它们不仅提供了更稳定和高效的延时执行机制,还遵循了JavaScript的异步编程模式,避免了不必要的资源浪费和性能瓶颈。掌握并正确运用...
总结一下,`setTimeout`是JavaScript中用于延迟执行任务的关键工具,它在模拟站长之家导航这类动态效果中发挥着重要作用,可以创建各种动画、延时更新、交互响应等效果。通过巧妙地结合`setTimeout`与其他技术,我们...
然而,自定义延时方法能够提供更多的灵活性和控制能力,比如更直观地传入秒数而非毫秒数进行延时,这在某些情况下可以使代码更加易读和维护。 #### 实现细节 以下是一种常见的自定义JavaScript延时方法的实现方式...
上述测试结果显示,即使设置延时为0,回调函数的实际执行时间在不同浏览器中有所差异,通常在1到20毫秒之间。这表明浏览器在处理事件队列的优先级和调度上有自己的策略。例如,IE浏览器在直接执行脚本和响应用户...
首先,`setTimeout`函数用于在指定的毫秒数后调用一个函数或执行一段代码。它的基本语法是: ```javascript setTimeout(function, delay, param1, param2, ...); ``` 这里的`function`是要执行的函数,`delay`是...
在编程领域,毫秒级时钟延时是一个常见的需求,特别是在需要精确控制程序执行流程或者进行性能测试的场景。这个“商业编程-源码-这是一个产生产生毫秒级时钟延时的程序”可能包含了实现这一功能的源代码。在不同的...
1. 实现延时操作:开发者可以利用setTimeout进行延时处理,比如表单验证、页面加载中的提示等。 2. 防抖和节流:利用setTimeout实现防抖(debounce)和节流(throttle)可以优化性能,减少资源消耗。 3. 倒计时和...
当使用setTimeout或setInterval设置延时时,如果提供的毫秒数超出了这个范围,它们就会出现一些不可预测的行为。 具体来说,setTimeout和setInterval可以接受的最大延时值是2^31-1毫秒,换算成时间则是大约24.8天。...
第二个参数是延迟时间,单位是毫秒(1秒=1000毫秒)。在设定时间到达之后,浏览器会执行第一个参数中指定的函数或代码。 ```javascript // 使用字符串执行代码 setTimeout("alert('Hello, world!')", 3000); // ...
这种功能通常通过延时执行来实现,其中最常用的工具就是`setTimeout`函数。在这个场景中,"javascript延时执行跳转或执行函数"涉及到的技术点主要包括`setTimeout`、`window.location`对象以及回调函数(callback)...
当setTimeout的第二个参数小于60毫秒时,Vue可能将这两个类的添加视为同时发生,从而失去了过渡动画。 解决这个问题的关键在于理解Vue的渲染流程,并确保setTimeout的间隔足够让Vue完成每次状态更新的渲染。对于...
timer = setTimeout(() => { delayMenu.style.display = 'block'; // 显示菜单 }, 500); // 延迟500毫秒 }); // 鼠标离开事件 menuTrigger.addEventListener('mouseout', () => { clearTimeout(timer); // 清除...
总结一下,`setTimeout`在JavaScript中用于延时执行任务,可以通过匿名函数或箭头函数来传递参数。当多个`setTimeout`涉及到共享变量时,需要注意作用域和闭包的影响,以确保每个定时器都能正确地获取其需要的参数。...
这里的`function()`是需要定时执行的代码,`delay`则是延迟执行的时间,以毫秒为单位。例如,延迟5秒执行,`delay`应设置为`5 * 1000`。`timerName`是返回的定时器标识,可用于清除定时器,即`clearTimeout...
`setTimeout`函数允许我们设置一个延时,在指定的毫秒数之后只执行一次回调函数。其基本语法结构如下: ```javascript setTimeout(callback, delay, [param1, param2, ...]); ``` - **callback**: 指定要在延迟...
Javascript的setTimeOut和setInterval函数应用非常广泛,它们都用来处理延时和定时任务,比如打开网页一段时间后弹出一个登录框,页面每隔一段时间发送异步请求获取最新数据等等。但它们的应用是有区别的。 ...
这个插件使用了`setTimeout`来实现延迟执行,并通过`clearTimeout`在必要的时候取消已设置的延时任务。`self.data('delayTimer')`用来存储定时器ID,以便在需要时清除。 `jQuery.mouseDelay.min.js`和`jQuery....
在JavaScript中,我们可以使用`setTimeout`函数来实现延时执行特定操作,比如延迟显示提示框或者控制其他UI元素的动态效果。在这个实例中,我们将探讨如何创建一个延时显示提示框的特效,这个特效不仅限于警告框,还...