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加一、判断循环是否结束。写代码应该尽量让代码指责单一,不是长度越短越好。
每循环一次都生成一个新的数组对象,这样真地好?
13 回答12.8k 阅读
7 回答1.9k 阅读
3 回答1.1k 阅读✓ 已解决
2 回答1.2k 阅读✓ 已解决
6 回答867 阅读✓ 已解决
6 回答1k 阅读
2 回答1.3k 阅读✓ 已解决
for 的基本结构不说了。
[i++]的得到 ['1','2','3']中的 第[i]个元素,
同时 也会赋值给 test, 然后 i++
i超出索引的时候返回 undefined, 此时 也会 退出 for循环,
只不过是简写了一大堆
原来是这样