1.setTimeout 0 有什么作用
setTimeout的作用是将代码推迟到指定时间执行,如果指定时间为0,setTimeout(f,0)那么会立刻执行吗?
答案是不会。setTimeout(f,0)将第二个参数设为0,作用是让f在现有的任务(当前脚本的同步任务和“任务队列”中已有的事件)一结束就立刻执行,也就是说,setTimeout(f,0)的作用是,尽可能早的执行指定的任务,而并不是立刻就执行指定的任务。
例子:
setTimeout(function(){
console.log("执行setTimeout")
},0);
function a(){
console.log("a函数开始执行");
console.log("a函数执行完毕");
}
a();
//a函数开始执行
//a函数执行完毕
//执行setTimeout
2.setTimeout具体延时时间:
示例1:
var start = new Date();
setTimeout(function(){
var end = new Date();
console.log("Time elapsed:", end - start, "ms");
},500);
while(new Date() - start < 1000){};
这个程序的输出结果是至少1000ms
3.setTimeout 与for循环
for (var i = 0; i < 3; i++) {
setTimeout(function () {
console.log(i);
alert(i);
},0);
}//输出3,3,3
for (var i = 0; i < 3; i++) {
setTimeout(function (a) {
console.log(a);
alert(a);
}(i),0);
}输出:0,1,2
setTimeout目前仍在研究当中,有些地方偶也不是特别明白,后续会继续补充,如果各种看官有啥补充的,表示热烈欢迎。。。