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

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

输出:0 1 2 3 4

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

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

输出:5 5 5 5 5

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

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

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

或者:

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

输出:0 1 2 3 4

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

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

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

输出:5 5 5 5 5

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

5.再更改一下

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

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

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

setTimeout(undefined, ...);

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

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

6.对于promise的考察

 setTimeout(function() {
console.log(1)
}, 0);
new Promise(function executor(resolve) {
console.log(2);
for( var i=0 ; i<10000 ; i++ ) {
i == 9999 && resolve();
}
console.log(3);
}).then(function() {
console.log(4);
});
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

最新文章

  1. hibernate不同版本获取获取sessionFactory
  2. SQList
  3. 。U盘安装windows7操作系统
  4. MySql增删改查命令
  5. 记一次奇怪IE动态加载js的乱码
  6. c++函数重载
  7. Spring JdbcTemplate 的使用与学习(转)
  8. 开发一个App的成本是多少?
  9. info sed 中文不完全文档
  10. [问题解决]LaTex 进行中文文档操作
  11. Photon的使用
  12. 常用Select语句
  13. js的this作用域
  14. Linux Command Line(I): Beginner
  15. Spring Boot之Hello World
  16. K - 迷宫问题 POJ - 3984
  17. SAP MM PR中的Fixed ID字段与MD04里PR单据号后的星号
  18. 用NAME_N带入NAME 让显示格式变为 姓名(类型),类型在数据库中是1和0,显示效果为姓名(1),SQL写法
  19. mysql+redis+memcached
  20. 在 sql 语句出现 warning 之后,立刻执行 `show warnings;` 就可以看到 warning 提示信息

热门文章

  1. 《DSP using MATLAB》示例 Example 6.25
  2. 【spring源码学习】spring配置的事务方式是REQUIRED,但业务层抛出TransactionRequiredException异常问题
  3. sentry docker-compsoe 安装以及简单使用
  4. eclipse marketplace网络连接失败的解决方法
  5. 笔记:NPM 无限需要依赖问题解决
  6. HTML:target=_blank
  7. wdlinux重新编译nginx
  8. TCP/IP网络编程系列之四(初级)
  9. hdu 1576 A/B(拓展欧几里得)
  10. linux 文件权限详细说明