setTimeout 只执行一次 可用来实现js代码异步执行
setInterval 循环执行console.log((function(){
console.log(1);
setTimeout(function(){
console.log(2)
},1000)
setTimeout(function(){
console.log(3)
},0);
setTimeout(function(){
console.log(4)
},0);
console.log(5)
})())
console.log((function(){
console.log(1);
setTimeout(function(){
console.log(2)
},1000)
setTimeout(function(){
console.log(3)
},0);
setTimeout(function(){
console.log(4)
},0);
console.log(5)
})())
答案是什么呢? 答案是:
1 5 undefined 3 4 2
下面解析一下此题:
首先要储备的知识点是: 1、setTimeout 中的时间是 以 “ms” 为单位的, 而且 即便是 0ms 也是有时间的,因为setTimeout中的时间是有时间误差的; 2、如果函数没有 return 返回值, 那么 就会 出现 undefined ,不要问为啥出现undefined, 我也不知道!
这一点就能判断出 一部分答案了: 1 5 3 4 2
但是为啥还有个 “undefined” ?
因为最外层的 console.log() 里面包含的是一个立即执行函数 IIFE (Immediately Invoked Function Expression) ,居然没有return返回值,那肯定是undefined的了!
但是为啥要在“1 5 ”的后面呢?
因为“return xxxxx” 一般是写在函数的最后的,不然所以的console不就都不执行了嘛!可是即便写在最后,上面有setTimeout,那也得执行在setTimeout之前,但幸亏没有写return 不然,那几个setTimeout也不会执行的啦!
so 最后的答案想必我就不多嘴了吧!
最后声明: 如有错误,欢迎批评指出!再次谢过~~~