我有这段代码,
let array = ["cj1rdd9fc00013f69ccln57g0", "cj1rdda8x00023f69g9281ay8"];
for (let [key, value] of array) {
console.log(key, value);
}
我有这段代码,
let array = ["cj1rdd9fc00013f69ccln57g0", "cj1rdda8x00023f69g9281ay8"];
for (let [key, value] of array) {
console.log(key, value);
}
这里有一些幕后解释。
for..of
循环适用于可迭代对象。在每次迭代中,它都会调用iterator.next().value
以获取值。标准Array
实现有两种迭代器——一种只返回值,另一种返回[key, value]
对。如果您需要获取第二种类型的迭代器,请使用array.entries()
.
let array = ["cj1rdd9fc00013f69ccln57g0", "cj1rdda8x00023f69g9281ay8"];
for (let [key, value] of array.entries()) {
console.log(key, value);
}
下面是两种迭代器的演示:
var arr = ['a','b'];
var valueIterator = arr[Symbol.iterator]();
valueIterator.next().value; // returns a
valueIterator.next().value; // returns b
var arr = ['a','b'];
var valueKeyIterator = arr.entries();
valueKeyIterator.next().value; // returns [0, a]
valueKeyIterator.next().value; // returns [1, b]
让我们尝试了解这里发生的事情:
根据MDN-Docs,for..of
为分配提供每次迭代的值。
因此,当您这样做时for(var v of array)
,v
将保持价值。
现在,当您这样做时let [key, value]
,您正在使用称为Destructuring Assignment的东西。
它的作用是,对于给定的变量列表,它将在相应的索引值处分配值。
因此,在let [a,b] = [10, 20]
和a=10
中b=20
。
回到你的例子,
let [key, value] of array,
被评估为let [key, value] = "cj1rdd9fc00013f69ccln57g0"
,因此key
在第 0 个索引处保持值,也就是c
保持值j
。
如何获得所需的输出
您可以使用其他循环机制for
,例如array.forEach
等。
还有其他机制,如.map
, .filter
, .some
, .every
,.reduce
但它们有自己的用例,可以根据处理逻辑提出建议。
let array = ["cj1rdd9fc00013f69ccln57g0", "cj1rdda8x00023f69g9281ay8"];
array.forEach(function(value, index){
console.log(index, value)
})
https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Statements/for...of
工作方式for of
是每次它只获取值,而不是索引。
let array = ["cj1rdd9fc00013f69ccln57g0", "cj1rdda8x00023f69g9281ay8"];
for (let item of array) {
console.log(item);
}
如果要包含索引,请参阅此问题:
此代码,Console.log 数组
let array = ["cj1rdd9fc00013f69ccln57g0", "cj1rdda8x00023f69g9281ay8"];
var i,j,tempstring;
for (i=0,j=array.length; i<j; i++) {
tempstring = array[i];
console.log(tempstring);
}
这是一个解构赋值。这适用于 es6 Maps 而不是 Arrays 。对于数组,您可以只使用 for of loop 。
如果你想在每次迭代中使用一些花哨的迭代来获取数组的值和索引,试试这个。
let array = ["cj1rdd9fc00013f69ccln57g0", "cj1rdda8x00023f69g9281ay8"];
array.map((value, index) => {
console.log(index, key);
});