一文搞懂ES6中的Map和Set


Posted in Javascript onMay 20, 2019

Map

Map对象保存键值对。任何值(对象或者原始值) 都可以作为一个键或一个值。构造函数Map可以接受一个数组作为参数。

Map和Object的区别

•一个Object 的键只能是字符串或者 Symbols,但一个Map 的键可以是任意值。

•Map中的键值是有序的(FIFO 原则),而添加到对象中的键则不是。

•Map的键值对个数可以从 size 属性获取,而 Object 的键值对个数只能手动计算。

•Object 都有自己的原型,原型链上的键名有可能和你自己在对象上的设置的键名产生冲突。

1.Map对象的属性

•size:返回Map对象中所包含的键值对个数

1.Map对象的方法

•set(key, val): 向Map中添加新元素

•get(key): 通过键值查找特定的数值并返回

•has(key): 判断Map对象中是否有Key所对应的值,有返回true,否则返回false

•delete(key): 通过键值从Map中移除对应的数据

•clear(): 将这个Map中的所有元素删除

const m1 = new Map([['a', 111], ['b', 222]])
console.log(m1) // {"a" => 111, "b" => 222}
m1.get('a') // 111
const m2 = new Map([['c', 3]])
const m3 = new Map(m2)
m3.get('c') // 3
m3.has('c') // true
m3.set('d', 555)
m3.get('d') // 555

1.遍历方法

•keys():返回键名的遍历器

•values():返回键值的遍历器

•entries():返回键值对的遍历器

•forEach():使用回调函数遍历每个成员

const map = new Map([['a', 1], ['b', 2]])

for (let key of map.keys()) {
 console.log(key)
}
// "a"
// "b"

for (let value of map.values()) {
 console.log(value)
}
// 1
// 2

for (let item of map.entries()) {
 console.log(item)
}
// ["a", 1]
// ["b", 2]

// 或者
for (let [key, value] of map.entries()) {
 console.log(key, value)
}
// "a" 1
// "b" 2
// for...of...遍历map等同于使用map.entries()
for (let [key, value] of map) {
 console.log(key, value)
}
// "a" 1
// "b" 2

1.map与其他数据结构的互相转换

•map转换为数组(使用扩展运算符)

const arr = [[{'a': 1}, 111], ['b': 222]]

const myMap = new Map(arr)

[...myMap] // map转数组。 [[{'a': 1}, 111], ['b': 222]]
•Map与对象的互换
const obj = {}
const map = new Map(['a', 111], ['b', 222])
for(let [key,value] of map) {
 obj[key] = value
}
console.log(obj) // {a:111, b: 222}

•JSON字符串要转换成Map可以先利用JSON.parse()转换成数组或者对象,然后再转换即可。

Set

Set对象允许你存储任何类型的值,无论是原始值或者是对象引用。它类似于数组,但是成员的值都是唯一的,没有重复的值。

Set 本身是一个构造函数,用来生成Set 数据结构。Set函数可以接受一个数组(或者具有 iterable 接口的其他数据结构)作为参数,用来初始化。

Set中的特殊值

Set 对象存储的值总是唯一的,所以需要判断两个值是否恒等。有几个特殊值需要特殊对待:

•+0 与 -0 在存储判断唯一性的时候是恒等的,所以不重复

•undefined 与 undefined 是恒等的,所以不重复

•NaN 与 NaN 是不恒等的,但是在 Set 中认为NaN与NaN相等,所有只能存在一个,不重复。

1.Set实例对象的属性

•size:返回Set实例的成员总数。

1.Set实例对象的方法

•add(value):添加某个值,返回 Set 结构本身(可以链式调用)。

•delete(value):删除某个值,删除成功返回true,否则返回false。

•has(value):返回一个布尔值,表示该值是否为Set的成员。

•clear():清除所有成员,没有返回值。

const mySet = new Set(['a', 'a', 'b', 1, 2, 1])
console.log(mySet) // {'a', 'b', 1, 2}
myset.add('c').add({'a': 1})
console.log(mySet) // {'a', 'b', 1, 2, 'c', {a: 1}}
console.log(mySet.size) // 6
mySet.has(2) // true

1.遍历方法

•keys():返回键名的遍历器。

•values():返回键值的遍历器。
•entries():返回键值对的遍历器。

•forEach():使用回调函数遍历每个成员。

由于Set结构没有键名,只有键值(或者说键名和键值是同一个值),所以keys方法和values方法的行为完全一致。

const set = new Set(['a', 'b', 'c'])
for (let item of set.keys()) {
 console.log(item)
}
// a
// b
// c
for (let item of set.values()) {
 console.log(item)
}
// a
// b
// c
for (let item of set.entries()) {
 console.log(item)
}
// ["a", "a"]
// ["b", "b"]
// ["c", "c"]
// 直接遍历set实例,等同于遍历set实例的values方法
for (let i of set) {
 console.log(i)
}
// a
// b
// c
set.forEach((value, key) => console.log(key + ' : ' + value))
// a: a
// b: b
// c: c

1.Set 对象作用

•数组去重(利用扩展运算符)

const mySet = new Set([1, 2, 3, 4, 4])
[...mySet] // [1, 2, 3, 4]

•合并两个set对象

let a = new Set([1, 2, 3])
let b = new Set([4, 3, 2])
let union = new Set([...a, ...b]) // {1, 2, 3, 4}

•交集

let a = new Set([1, 2, 3])
let b = new Set([4, 3, 2])
let intersect = new Set([...a].filter(x => b.has(x))) // {2, 3} 利用数组的filter方法

•差集

let a = new Set([1, 2, 3])
let b = new Set([4, 3, 2])
let difference = new Set([...a].filter(x => !b.has(x))) // {1}

总结

以上所述是小编给大家介绍的一文搞懂ES6中的Map和Set,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
不能再简单的无闪刷新验证码原理很简单
Nov 05 Javascript
让网页根据不同IE版本显示不同的内容
Feb 08 Javascript
javascript常用方法、属性集合及NodeList 和 HTMLCollection 的浏览器差异
Dec 25 Javascript
Javascript的时间戳和php的时间戳转换注意事项
Apr 12 Javascript
Jquery $.getJSON 在IE下的缓存问题解决方法
Oct 10 Javascript
jQuery实现不断闪烁文字的方法
May 15 Javascript
javascript常用函数(2)
Nov 05 Javascript
vue.js异步上传文件前后端实现代码
Aug 22 Javascript
javascript按顺序加载运行js方法
Dec 01 Javascript
jQuery实现的鼠标响应缓冲动画效果示例
Feb 13 jQuery
JavaScript中call和apply方法的区别实例分析
Aug 03 Javascript
详解vue-cli项目在IE浏览器打开报错解决方法
Dec 10 Vue.js
详解vue 在移动端体验上的优化解决方案
May 20 #Javascript
vue-i18n结合Element-ui的配置方法
May 20 #Javascript
JS实现选项卡效果的代码实例
May 20 #Javascript
微信打开网址添加在浏览器中打开提示的办法
May 20 #Javascript
浅谈Vuex注入Vue生命周期的过程
May 20 #Javascript
微信小程序图表插件wx-charts用法实例详解
May 20 #Javascript
Nuxt项目支持eslint+pritter+typescript的实现
May 20 #Javascript
You might like
了解咖啡雨林联盟认证 什么是雨林认证 雨林认证是什么意思
2021/03/05 新手入门
ajax实现无刷新分页(php)
2010/07/18 PHP
推荐一款PHP+jQuery制作的列表分页的功能模块
2014/10/14 PHP
PHP中JSON的应用技巧
2015/10/10 PHP
Zend Framework教程之Application和Bootstrap用法详解
2016/03/10 PHP
PHP中如何防止外部恶意提交调用ajax接口
2016/04/11 PHP
php微信支付接口开发程序
2016/08/02 PHP
js基于qrcode.js生成二维码的方法【附demo插件源码下载】
2016/12/28 PHP
Function.prototype.bind用法示例
2013/09/16 Javascript
原生JS实现响应式瀑布流布局
2015/04/02 Javascript
JS实现仿QQ聊天窗口抖动特效
2015/05/10 Javascript
Linux系统中利用node.js提取Word(doc/docx)及PDF文本的内容
2017/06/17 Javascript
jquery实现简单拖拽效果
2020/07/20 jQuery
JavaScript实现点击图片换背景
2020/11/20 Javascript
[02:49]2014DOTA2电竞也是体育项目! 势要把荣誉带回中国!
2014/07/20 DOTA
[57:29]Alliance vs KG 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/17 DOTA
python获取指定网页上所有超链接的方法
2015/04/04 Python
实例解析Python设计模式编程之桥接模式的运用
2016/03/02 Python
详解Python中open()函数指定文件打开方式的用法
2016/06/04 Python
Python爬取十篇新闻统计TF-IDF
2018/01/03 Python
python中PS 图像调整算法原理之亮度调整
2019/06/28 Python
python全栈要学什么 python全栈学习路线
2019/06/28 Python
PyCharm2019 安装和配置教程详解附激活码
2020/07/31 Python
Python变量格式化输出实现原理解析
2020/08/06 Python
用canvas做一个DVD待机动画的实现代码
2019/04/12 HTML / CSS
香港万宁官方海外旗舰店:香港健与美连锁店
2018/09/27 全球购物
转党组织关系介绍信
2014/01/08 职场文书
房屋过户委托书范本
2014/10/07 职场文书
2014财务年度工作总结
2014/11/11 职场文书
2014年双拥工作总结
2014/11/21 职场文书
团员自我评价范文
2015/03/10 职场文书
自主招生学校推荐信范文
2015/03/26 职场文书
导游词之安徽九华山
2019/09/18 职场文书
JavaScript中时间格式化新思路toLocaleString()
2021/11/07 Javascript
python 管理系统实现mysql交互的示例代码
2021/12/06 Python
Python中的turtle画箭头,矩形,五角星
2022/03/16 Python