JavaScript --Map和Set, Iterable

Map

Map是一组键值对的结构,具有极快的查找速度。比如,要根据同学的名字查找对应的成绩,我们用Map实现,只需要一个“名字“ - ”成绩“的对照表,直接根据名字查找成绩,无论这个表多大,查找速度都不会变慢。用JavaScript写一个Map:

var m = new Map([['Michael', 95], ['Bob', 75], ['Tracy', 85]]);
m.get('Michael');

从而直接得到Michael的成绩95了,初始化Map需要一个二维数组,或者直接初始化一个空Map,Map具有以下的方法:

var m = new Map(); //空Map
m.set('Adam', 67);	//添加新的key-value
m.set('Bob', 59);
m.has('Adam');	//是否存在key 'Adam': true
m.get('Adam');	67
m.delete('Adam');	//删除key 'Adam'
m.get('Adam');

而由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉。

Set

Set和Map类似,也是一组key的集合,但不存储value。由于key不能重复,所以在Set中,没有重复的key。要创建一个Set,需要提供一个Array作为输入,或者直接创建一个空的Set:
var s1 = new Set();	// 空Set
var s2 = new Set([1, 2, 3]); // 含1, 2, 3
var s = new Set([1, 2, 3, 3, '3']);
s;	// Set {1, 2, 3, '3'}

Set具有以下函数:
1. add(key)方法可以添加元素到Set中,可以重复添加,但不会有效果。

>>> s.add(4)
>>> s
{1, 2, 3, 4}
>>> s.add(4)
>>> s
{1, 2, 3, 4}

2. delete(key)方法可以删除元素:
var s = new Set([1, 2, 3]);
s; // Set {1, 2, 3}
s.delete(3);
s; // Set {1, 2}

Map和Set是ES6标准的新增的数据类型,要确保浏览器支持使用。

Iterable

遍历Array可以使用下标循环,遍历Map和Set就无法使用下标。为了统一集合类型,ES6标准引入了新的iterable类型,Array、Map和Set都属于iterable类型。具有iterable类型的集合都可以通过新的for ... of循环来遍历。
for ... of循环是ES6引入的新的语法,例如:

'use strict';
var a = [1, 2, 3];
for(var x of a) {

}

用for ... of 循环遍历集合,用法很简单,例子如下:

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) {
	alert(x);
}

for(var x of s) {
	alert(x);
}

for(var x of m) {
	alert(x[0] + '=' + x[1]);
}

for...in 循环遍历的实际是对象的属性名称。一个Array数组实际上也是一个对象,它的每个元素的索引被称为一个属性。例如

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

for ... in 循环将把name包含在内,但Array的length属性不包含在内。
for ... of 循环只循环集合本身的元素:

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


更好的方式是直接是使用iterable内置的forEach方法,它接收一个函数,每次迭代都自动回调该函数。以Array为例:

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

Set与Array类似,但Set没有索引

var s = new Set(['A', 'B', 'C']);
s.forEach(function (element, sameElement, set) {
    alert(element);
});

Map的回调函数参数依次为value, key, map本身:

var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);
m.forEach(function (value, key, map) {
    alert(value);
});

当然,由于JavaScript的函数调用不要求参数必须一致,因此可以忽略它们。
var a = ['A', 'B', 'C'];
a.forEach(function (element) {
    alert(element);
});






猜你喜欢

转载自blog.csdn.net/WilliamChancwl/article/details/78231448