欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳談js遍歷集合(Array,Map,Set)

 更新時(shí)間:2017年04月06日 10:48:06   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇詳談js遍歷集合(Array,Map,Set)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

Array可以使用下標(biāo),Map和Set不能使用下標(biāo),ES6引入了iterable類型,Array,Map,Set都屬于iterable類型,它們可以使用for...of循環(huán)來(lái)遍歷:

var a = ['A', 'B', 'C'];
var s = new Set(['A', 'B', 'C']);
var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);
for (var x of a) { // 遍歷Array
  alert(x);
}
for (var x of s) { // 遍歷Set
  alert(x);
}
for (var x of m) { // 遍歷Map
  alert(x[0] + '=' + x[1]);
}

>for...of與for...in的區(qū)別:for ... in循環(huán)由于歷史遺留問題,它遍歷的實(shí)際上是對(duì)象的屬性名稱。一個(gè)Array數(shù)組實(shí)際上也是一個(gè)對(duì)象,它的每個(gè)元素的索引被視為一個(gè)屬性。

當(dāng)我們手動(dòng)給Array對(duì)象添加了額外的屬性后,for ... in循環(huán)將帶來(lái)意想不到的意外效果:

var a = ['A', 'B', 'C'];
a.name = 'Hello';
for (var x in a) {
  alert(x); // '0', '1', '2', 'name'
}

var a = ['A', 'B', 'C'];
a.name = 'Hello';
for (var x of a) {
  alert(x); // 'A', 'B', 'C'
}

>更好的方式:iterable內(nèi)置的forEach方法:

var a = ['A', 'B', 'C'];
a.forEach(function (element, index, array) {
  // element: 指向當(dāng)前元素的值
  // index: 指向當(dāng)前索引
  // array: 指向Array對(duì)象本身
  alert(element);//'A','B','C'
});

var s = new Set(['A', 'B', 'C']);
s.forEach(function (element, sameElement, set) {
  alert("參數(shù)1="+element+",參數(shù)2="+sameElement);
});
//參數(shù)1=A,參數(shù)2=A
//參數(shù)1=B,參數(shù)2=B
//參數(shù)1=C,參數(shù)2=C

var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);
m.forEach(function (value, key, map) {
  alert("參數(shù)1="+value+",參數(shù)2="+key);
});
//參數(shù)1=x,參數(shù)2=1
//參數(shù)1=y,參數(shù)2=2
//參數(shù)1=z,參數(shù)2=3

以上這篇詳談js遍歷集合(Array,Map,Set)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論