博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一道容易栽坑的有趣的面试题(关于js,定时器,闭包等)
阅读量:6955 次
发布时间:2019-06-27

本文共 1771 字,大约阅读时间需要 5 分钟。

1.首先下面代码输出什么?

1 for (var i = 0; i < 5; i++) {2   console.log(i);3 }

输出:0 1 2 3 4

 

2.上面只是普通的输出,没有陷阱再看下面这个题(套路开始了)

1 for (var i = 0; i < 5; i++) {2   setTimeout(function() {3     console.log(i);4   }, 1000 * i);5 }

输出:5 5 5 5 5 

setTimeout 会延迟执行,那么执行到 console.log 的时候,其实 i 已经变成 5 了,因此会输出5个5

 

3.上面的题超出我们的预想,我们肯定想得到的是0 1 2 3 4,那么问题来了 怎么才能输出0 1 2 3 4呢

1 for (var i = 0; i < 5; i++) {2   (function(i) {3     setTimeout(function() {4       console.log(i);5     }, i * 1000);6   })(i);7 }

或者:

1 for(var i = 0; i < 5; i++) {2     setTimeout(function(i) {3         return function() {4             console.log(i);5         };6     }(i), i * 1000);7 }

输出:0 1 2 3 4

加上闭包,就能解决这个问题

 

4.如第一个假设删除了function(i)中的i呢,怎么办?

1 for (var i = 0; i < 5; i++) {2   (function() {3     setTimeout(function() {4       console.log(i);5     }, i * 1000);6   })(i);7 }

输出:5 5 5 5 5 

内部其实没有对 i 保持引用,其实会变成输出 5个5

 

5.再更改一下

1 for (var i = 0; i < 5; i++) {2   setTimeout((function(i) {3     console.log(i);4   })(i), i * 1000);5 }

输出:0 1 2 3 4 (立刻输出,没有时间间隔)

给 setTimeout 传递了一个立即执行函数。setTimeout 可以接受函数或者字符串作为参数,那么这里立即执行函数是个啥呢,应该是个 undefined ,也就是说等价于:

setTimeout(undefined, ...);

而立即执行函数会立即执行,那么应该是立马输出的。

“应该是立马输出 0 到 4 吧。”

 

6.对于promise的考察

1 setTimeout(function() { 2   console.log(1) 3 }, 0); 4 new Promise(function executor(resolve) { 5   console.log(2); 6   for( var i=0 ; i<10000 ; i++ ) { 7     i == 9999 && resolve(); 8   } 9   console.log(3);10 }).then(function() {11   console.log(4);12 });13 console.log(5);

输出:2 3 5 4 1

考察 JavaScript 的运行机制的,

首先先碰到一个 setTimeout,于是会先设置一个定时,在定时结束后将传递这个函数放到任务队列里面,因此开始肯定不会输出 1 。

然后是一个 Promise,里面的函数是直接执行的,因此应该直接输出 2 3 。

然后,Promise 的 then 应当会放到当前 tick 的最后,但是还是在当前 tick 中。

因此,应当先输出 5,然后再输出 4 。

最后在到下一个 tick,就是 1 。

所以输出:2 3 5 4 1

 

转载于:https://www.cnblogs.com/zhangxue521/p/6710319.html

你可能感兴趣的文章
高性能WEB开发之如何减少请求数
查看>>
python3-字典的循环
查看>>
我的友情链接
查看>>
系统监控工具汇总
查看>>
win7 系统保留分区 BCDedit
查看>>
rsync 实时同步
查看>>
集群简单概述
查看>>
Windows 2012初探之一:分区管理
查看>>
python之文件的基本操作
查看>>
【2013-6-28】零售快消行业最佳实践交流会
查看>>
Nfs 网络文件系统
查看>>
debian或ubuntu修改时区
查看>>
mysql升级:rpm包安装升级
查看>>
SQL Server 2005 XML 操作总结(二)示例
查看>>
测试代码是否按代码风格显示
查看>>
Zabbix 3.4.3 使用SNMP监控H3C交换机端口流量
查看>>
三大家族轻松管理CentOS 7网络属性配置
查看>>
Zabbix汇总分组流量
查看>>
Kali***(二)之被动信息收集——DNS字典爆破
查看>>
MySQL 存储过程
查看>>