Map 和Object的区别
JavaScript的默认对象表示方式{}
可以视为其他语言中的Map
或Dictionary
的数据结构,即一组键值对。
但是JavaScript的对象有个小问题,就是键必须是字符串。但实际上Number或者其他数据类型作为键也是非常合理的。
为了解决这个问题,最新的ES6规范引入了新的数据类型Map
。
ES6 提供了 Map 数据结构。它类似于对象,也是键值对的集合,但是“键”的范围不限于
字符串
,各种类型的值(包括对象)都可以当作键
。
也就是说,Object`` 结构提供了“``字符串—值``”的对应
,
Map 结构提供了“``值—值``”的对应
,是一种更完善的 Hash 结构实现。
Map
Map
是一组键值对的结构,具有极快的查找速度。 注意区分 map()数组遍历方法。
新建Map,需要一个二维数组存储键值对。
var map = new Map([
['Michael', 95], ['Bob', 75], ['Tracy', 85]
]);
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'); // undefined
m.size; // size 属性获取映射中的键/值对的数量
m.clear(); // 清除这个映射实例中的所有键/值对
set方法 添加新的key-value
set() 方法返回映射实例,因此可以把多个操作连缀起来,包括初 始化声明:
const m = new Map().set("key1","val1");
m.set("key2","val2").set("key3","val3");
alert(m.size); // 3
Set
Set和Map类似,也是一组key的集合,但不存储value。所以需要一个一维数组存储key即可。由于key不能重复,所以,在Set中,没有重复的key。
创建Set,需要一个一维数组存储key
要创建一个Set
,需要提供一个Array
作为输入,或者直接创建一个空Set
:
var s1 = new Set(); // 空Set
var s2 = new Set([1, 2, 3]); // 含1, 2, 3
重复元素在Set
中自动被过滤:
var s = new Set([1, 2, 3, 3, '3']);
s; // Set {1, 2, 3, "3"}
注意数字3
和字符串'3'
是不同的元素。
通过add(key)
方法可以添加元素到Set
中,可以重复添加,但不会有效果:
s.add(4);
s; // Set {1, 2, 3, 4}
s.add(4);
s; // 仍然是 Set {1, 2, 3, 4}
通过delete(key)
方法可以删除元素:
var s = new Set([1, 2, 3]);
s; // Set {1, 2, 3}
s.delete(3);
s; // Set {1, 2}