昨晚在一个交流群里看到有位网友提了一个他的面试题求助答疑。恰好我也有看到,就对这个问题思考了一下,以为这道题对理解 JavaScript 做用域仍是颇有帮助的,特此又把本身的解题思路梳理了一遍,但愿对其它人有所帮助。html
1 var arr = [1, 2, 3]; 2 for (var i = 0, j; j = arr[i++];) { 3 console.log(j); 4 } 5
6 console.log('---------'); 7 console.log(i); 8 console.log('---------'); 9 console.log(j); 10 console.log('---------');
在解题前,咱们先回顾下 JavaScript 中,变量域相关的知识。面试
全局变量是指在任何地方均可以访问的变量,有两种状况spa
两点要注意的地方code
先看代码:htm
1 alert(i); // 输出 undefined 2 3 for (var i = 0; i < 1; i++){}; 4 5 alert(i); // 输出1
开始咱们的解题blog
i++ 是在 i 使用后再自加:ip
第一次执行时,j=arr[0],以后 i=1,console.log(j) 输出 1 作用域
第二次执行时,j=arr[1],以后 i=2,ocnsole.log(j) 输出 2get
第三次执行时,j=arr[2],以后 i=3,ocnsole.log(j) 输出 3io
第四次(不符合 for 条件),j=arr[3] 为 undefined,以后 i=4,ocnsole.log(j) 没有输出,退出 for 循环
for 语句执行结束后,console.log(i) 由上分析可知输出 4,console.log(j) 输出 undefined
最后输出结果为:
1
2
3
---------
4
---------
undefined
---------
针对上面的分析和结果,想必你们都已经搞清楚了吧,而后咱们开始触类旁通吧。
题目:
1 var arr = [1, 2, 3]; 2 for (var i = 0, j; j = arr[++i];) { 3 console.log(j); 4 } 5
6 console.log('---------'); 7 console.log(i); 8 console.log('---------'); 9 console.log(j); 10 console.log('---------');
答案:
1 2 2 3 3 --------- 4 3 5 --------- 6 undefined 7 ---------
题目:
1 function xxx() { 2 var arr = [1, 2, 3]; 3 for (var i = 0, j; j = arr[i++];) { 4 console.log(j); 5 } 6 } 7 xxx(); 8
9 console.log('---------'); 10 console.log(i); 11 console.log('---------'); 12 console.log(j); 13 console.log('---------');
答案:
1
2
3
--------- 报错:Uncaught ReferenceError: i is not defined