JavaScript --Map和Set, Iterable

来源:互联网 发布:广东软件行业协会 招聘 编辑:程序博客网 时间:2024/05/18 14:22

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(); //空Mapm.set('Adam', 67);//添加新的key-valuem.set('Bob', 59);m.has('Adam');//是否存在key 'Adam': truem.get('Adam');67m.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();// 空Setvar s2 = new Set([1, 2, 3]); // 含1, 2, 3var 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);});






原创粉丝点击