遍歷Array可以采用下標(biāo)循環(huán)掸茅,遍歷Map和Set就無法使用下標(biāo)行疏。為了統(tǒng)一集合類型叼架,ES6標(biāo)準(zhǔn)引入了新的iterable類型畔裕,Array、Map和Set都屬于iterable類型乖订。
具有iterable類型的集合可以通過新的for ... of循環(huán)來遍歷扮饶。
for ... of循環(huán)是ES6引入的新的語法,請(qǐng)測(cè)試你的瀏覽器是否支持:
'use strict';
var a = [1, 2, 3];
for (var x of a) {
}
alert('你的瀏覽器支持for ... of');
然而乍构,更好的方式是直接使用iterable內(nèi)置的forEach方法兑牡,它接收一個(gè)函數(shù)其监,每次迭代就自動(dòng)回調(diào)該函數(shù)。以Array為例:
var a = ['A', 'B', 'C'];
a.forEach(function (element, index, array) {
// element: 指向當(dāng)前元素的值
// index: 指向當(dāng)前索引
// array: 指向Array對(duì)象本身
alert(element);
});
注意,forEach()方法是ES5.1標(biāo)準(zhǔn)引入的收毫,你需要測(cè)試瀏覽器是否支持。
Set與Array類似硫椰,但Set沒有索引制跟,因此回調(diào)函數(shù)的前兩個(gè)參數(shù)都是元素本身:
var s = new Set(['A', 'B', 'C']);
s.forEach(function (element, sameElement, set) {
alert(element);
});
Map的回調(diào)函數(shù)參數(shù)依次為value、key和map本身:
var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);
m.forEach(function (value, key, map) {
alert(value);
});
如果對(duì)某些參數(shù)不感興趣仪召,由于JavaScript的函數(shù)調(diào)用不要求參數(shù)必須一致寨蹋,因此可以忽略它們。例如扔茅,只需要獲得Array的element:
var a = ['A', 'B', 'C'];
a.forEach(function (element) {
alert(element);
});