Map 和Object的区别

JavaScript的默认对象表示方式{}可以视为其他语言中的MapDictionary的数据结构,即一组键值对。

但是JavaScript的对象有个小问题,就是键必须是字符串。但实际上Number或者其他数据类型作为键也是非常合理的。
为了解决这个问题,最新的ES6规范引入了新的数据类型Map

ES6 提供了 Map 数据结构。它类似于对象,也是键值对的集合,但是“键”的范围不限于字符串,各种类型的值(包括对象)都可以当作键

也就是说,Object`` 结构提供了“``字符串—值``”的对应

Map 结构提供了“``值—值``”的对应,是一种更完善的 Hash 结构实现。

字典Map和Set----数组格式的键值对 - 图1

Map

Map是一组键值对的结构,具有极快的查找速度。 注意区分 map()数组遍历方法。

新建Map,需要一个二维数组存储键值对。

  1. var map = new Map([
  2. ['Michael', 95], ['Bob', 75], ['Tracy', 85]
  3. ]);


Map具有以下方法:

  1. var m = new Map(); // 空Map
  2. m.set('Adam', 67); // 添加新的key-value
  3. m.set('Bob', 59);
  4. m.has('Adam'); // 是否存在key 'Adam': true
  5. m.get('Adam'); // 67
  6. m.delete('Adam'); // 删除key 'Adam'
  7. m.get('Adam'); // undefined
  8. m.size; // size 属性获取映射中的键/值对的数量
  9. m.clear(); // 清除这个映射实例中的所有键/值对


set方法 添加新的key-value

set() 方法返回映射实例,因此可以把多个操作连缀起来,包括初 始化声明:

  1. const m = new Map().set("key1","val1");
  2. m.set("key2","val2").set("key3","val3");
  3. alert(m.size); // 3

Set

Set和Map类似,也是一组key的集合,但不存储value。所以需要一个一维数组存储key即可。由于key不能重复,所以,在Set中,没有重复的key

创建Set,需要一个一维数组存储key

要创建一个Set,需要提供一个Array作为输入,或者直接创建一个空Set

  1. var s1 = new Set(); // 空Set
  2. var s2 = new Set([1, 2, 3]); // 含1, 2, 3

重复元素在Set中自动被过滤:

  1. var s = new Set([1, 2, 3, 3, '3']);
  2. s; // Set {1, 2, 3, "3"}

注意数字3和字符串'3'是不同的元素。

通过add(key)方法可以添加元素到Set中,可以重复添加,但不会有效果:

  1. s.add(4);
  2. s; // Set {1, 2, 3, 4}
  3. s.add(4);
  4. s; // 仍然是 Set {1, 2, 3, 4}

通过delete(key)方法可以删除元素:

  1. var s = new Set([1, 2, 3]);
  2. s; // Set {1, 2, 3}
  3. s.delete(3);
  4. s; // Set {1, 2}

参考

廖雪峰javascript教程