for(var i = 0 , test = ['1','2','3']; i < test.length ; i++){
console.log(test[i]);
}
for(var i = 0 , test; test = ['1','2','3'][i++];){ //这里有点儿看不明白,为什么要这么写,这么写有什么好处呢?
console.log(i);
}
for(var i = 0 , test = ['1','2','3']; i < test.length ; i++){
console.log(test[i]);
}
for(var i = 0 , test; test = ['1','2','3'][i++];){ //这里有点儿看不明白,为什么要这么写,这么写有什么好处呢?
console.log(i);
}
并不觉得这样写有什么好:
不好理解。在一个表达式中同时完成新建数组、循环计数器i加一、判断循环是否结束。写代码应该尽量让代码指责单一,不是长度越短越好。
每循环一次都生成一个新的数组对象,这样真地好?
10 回答11.2k 阅读
5 回答4.8k 阅读✓ 已解决
4 回答3.1k 阅读✓ 已解决
2 回答2.7k 阅读✓ 已解决
3 回答2.3k 阅读✓ 已解决
3 回答2.2k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
for 的基本结构不说了。
[i++]的得到 ['1','2','3']中的 第[i]个元素,
同时 也会赋值给 test, 然后 i++
i超出索引的时候返回 undefined, 此时 也会 退出 for循环,
只不过是简写了一大堆
原来是这样