ES6中增加了Map和Set两种新的数据结构,Map是类似Object的一种键值对集合,区别在于Map的键不仅限于是字符串,其他各种类型的值包括对象都可以成为Map的键;Set是类似数组的一种数据结构,不同点在于Set中没有重复的值。
1 Map
创建Map对象
代码语言:javascript复制var map = new Map();
Map和Object有点类似,都是键值对来存储数据,和Object不同的是,JavaScript支持的所有类型都可以当作Map的key
代码语言:javascript复制var map = new Map();
map.set({}, "对象")
map.set([], "数组")
map.set("字符串", "字符串")
map.set(1, 1)
map.set(null, null)
map.set(undefined, undefined)
console.log(map)
方法
代码语言:javascript复制Map.prototype.clear()
移除Map对象的所有键/值对 。
代码语言:javascript复制Map.prototype.delete(key)
如果 Map 对象中存在该元素,则移除它并返回 true;否则如果该元素不存在则返回 false。随后调用 Map.prototype.has(key) 将返回 false 。
代码语言:javascript复制Map.prototype.entries()
返回一个新的 Iterator 对象,它按插入顺序包含了Map对象中每个元素的 [key, value] 数组。
代码语言:javascript复制Map.prototype.forEach(callbackFn[, thisArg])
按插入顺序,为 Map对象里的每一键值对调用一次callbackFn函数。如果为forEach提供了thisArg,它将在每次回调中作为this值。
代码语言:javascript复制Map.prototype.get(key)
返回键对应的值,如果不存在,则返回undefined。
代码语言:javascript复制Map.prototype.has(key)
返回一个布尔值,表示Map实例是否包含键对应的值。
代码语言:javascript复制Map.prototype.keys()
返回一个新的 Iterator对象, 它按插入顺序包含了Map对象中每个元素的键 。
代码语言:javascript复制Map.prototype.set(key, value)
设置Map对象中键的值。返回该Map对象。
代码语言:javascript复制Map.prototype.values()
返回一个新的Iterator对象,它按插入顺序包含了Map对象中每个元素的值 。
代码语言:javascript复制Map.prototype[@@iterator]()
返回一个新的Iterator对象,它按插入顺序包含了Map对象中每个元素的 [key, value] 数组。
2 Set
Set和Map类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在Set中,没有重复的key。
代码语言:javascript复制var set = new Set();
重复的元素会自动过滤
代码语言:javascript复制var set = new Set([1, 2, 3, 3, '3']);
set // Set {1, 2, 3, "3"}
方法
代码语言:javascript复制Set.prototype.add(value)
在Set对象尾部添加一个元素。返回该Set对象。
代码语言:javascript复制Set.prototype.clear()
移除Set对象内的所有元素。
代码语言:javascript复制Set.prototype.delete(value)
移除Set中与这个值相等的元素,返回Set.prototype.has(value)在这个操作前会返回的值(即如果该元素存在,返回true,否则返回false)。Set.prototype.has(value)在此后会返回false。
代码语言:javascript复制Set.prototype.entries()
返回一个新的迭代器对象,该对象包含Set对象中的按插入顺序排列的所有元素的值的[value, value]数组。为了使这个方法和Map对象保持相似, 每个值的键和值相等。
代码语言:javascript复制Set.prototype.forEach(callbackFn[, thisArg])
按照插入顺序,为Set对象中的每一个值调用一次callBackFn。如果提供了thisArg参数,回调中的this会是这个参数。
代码语言:javascript复制Set.prototype.has(value)
返回一个布尔值,表示该值在Set中存在与否。
代码语言:javascript复制Set.prototype.keys()
与values()方法相同,返回一个新的迭代器对象,该对象包含Set对象中的按插入顺序排列的所有元素的值。
代码语言:javascript复制Set.prototype.values()
返回一个新的迭代器对象,该对象包含Set对象中的按插入顺序排列的所有元素的值。
代码语言:javascript复制Set.prototype[@@iterator]()
返回一个新的迭代器对象,该对象包含Set对象中的按插入顺序排列的所有元素的值。
小结
Map和Set是ES6标准新增的数据类型,
Set和Map主要的应用场景在于数组去重和数据存储,
Set是一种叫做集合的数据结构,Map是一种叫做字典的数据结构