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');
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'}
1. add(key)方法可以添加元素到Set中,可以重复添加,但不会有效果。
>>> s.add(4)
>>> s
{1, 2, 3, 4}
>>> s.add(4)
>>> s
{1, 2, 3, 4}
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);
});