有趣的试题

考验对JS运行机制 和 作用域的了解。

如下两个示例:

(1)

for (var a = 0;a<5;a++) {
    setTimeout(function () {
        console.log(new Date, a)   // a是取全局作用域,for循环已经执行完成a=5
     }, 1000)
   }
console.log(new Date, a)

结果:

 

 

(2)

for (var a = 0;a<5;a++) {
    setTimeout(function (j) {      // j 保存在作用域
       console.log(new Date, j)
    },1000,a)
  }
console.log(new Date, a)

结果:

 (3)

let arr = [1,2,3]
function play (arr) {
   arr[3] = 4;
   arr = [100];   // arr = [100] 新对象赋值给arr,切断了内部作用域arr和外部arr的联系,分别指向于不同的对象
} 
play(arr)
console.log(arr)

结果:

 

 

 

 个人总结:

1. js是单线程的语言,任务有分为 同步 和 异步 setTimeout() 属于异步任务,异步任务会在同步任务后面执行。

2. 怎么区别同步异步 存在回调函数为异步

教程参考地址:阮一峰老师的《JavaScript 运行机制详解:再谈Event Loop》

posted @ 2019-12-24 10:58  幻城love  阅读(193)  评论(0编辑  收藏  举报