js中Map和Set的用法及区别实例详解


Posted in Javascript onFebruary 15, 2022

首先了解一下 Map

Map 是一组键值对的结构,和 JSON 对象类似。

(1) Map数据结构如下

这里我们可以看到的是Map的数据结构是一个键值对的结构

js中Map和Set的用法及区别实例详解

(2) key 不仅可以是字符串还可以是对象

var obj ={name:"小如",age:9}
let map = new Map()
map.set(obj,"111")

打印结果如下

js中Map和Set的用法及区别实例详解

(3) Map常用语法如下

//初始化`Map`需要一个二维数组(请看 Map 数据结构),或者直接初始化一个空`Map` 
let map = new Map();

//添加key和value值
map.set('Amy','女')
map.set('liuQi','男')

//是否存在key,存在返回true,反之为false
map.has('Amy') //true
map.has('amy') //false

//根据key获取value
map.get('Amy') //女

//删除 key为Amy的value
map.delete('Amy')
map.get('Amy') //undefined  删除成功

(4) 一个key只能对应一个value,多次对一个key放入value,后面的值会把前面的值覆盖掉

var map =new Map
map.set('Amy',"女")
map.set('Amy',"男")
console.log(map)

打印结果如下

js中Map和Set的用法及区别实例详解

再来了解一下 Set

Set 对象类似于数组,且成员的值都是唯一的

(1) 打印出的数据结构如下

这里打印出来是一个对象

js中Map和Set的用法及区别实例详解

(2) 最常用来去重使用,去重方法有很多但是都没有它运行的快。

var arr=[1,3,4,2,5,1,4]
// 这里原本是一个对象用了es6的语法 转化成了数组,就是转化数组之前已经过滤掉了重复的元素了
var arr2=[...new Set(arr)] //[1,3,4,2,5]

(3) Set常用语法如下

//初始化一个Set ,需要一个Array数组,要么空Set
var set = new Set([1,2,3,5,6]) 
console.log(set)  // {1, 2, 3, 5, 6}

//添加元素到Set中
set.add(7) //{1, 2, 3, 5, 6, 7}

//删除Set中的元素
set.delete(3) // {1, 2, 5, 6, 7}

//检测是否含有此元素,有为true,没有则为false
set.has(2) //true

总结Map和Set的区别

(1) 这两种方法具有极快的查找速度;那么下面我们来对比一下Map,Set,Array 的执行时间

//首先初始化数据
var lng=100
var arr =new Array(lng).fill(2)
var set =new Set(arr)
let map =new Map()
for(var i=0;i<lng;i++){
arr[i]=i
map.set(i,arr[i])
}

// Array
console.time()
for(var j=0;j<lng;j++){
arr.includes(j)
}
console.timeEnd()  //default: 0.01220703125 ms


// Set
console.time()
for(var j=0;j<lng;j++){
set.has(j)
}
console.timeEnd()  // default: 0.005859375 ms

// Map
console.time()
for(var j=0;j<lng;j++){
map.has(j)
}
console.timeEnd()
// default: 0.007080078125 ms

通过以上几种方法我们可以看到,Set执行时间最短,那么查找速度最快,当然了Set 和 Map的查找速度都很快想差不大,所以说这两种方法具有极快的查找速度。

(2) 初始化需要的值不一样,Map需要的是一个二维数组,而Set 需要的是一维 Array 数组

(3) Map 和 Set 都不允许键重复

(4) Map的键是不能修改,但是键对应的值是可以修改的;Set不能通过迭代器来改变Set的值,因为Set的值就是键。

(5) Map 是键值对的存在,值也不作为健;而 Set 没有 value 只有 key,value 就是 key;

结语:

Map 和 Set 数据结构是ES6语法,最大优点就是运行时间少大大提高了性能。

到此这篇关于js中Map和Set用法及区别的文章就介绍到这了,更多相关js中Map和Set用法区别内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
jQuery 遍历json数组的实现代码
Sep 22 Javascript
JavaScript中函数声明优先于变量声明的实例分析
Mar 01 Javascript
javascript限制用户只能输汉字中文的方法
Nov 20 Javascript
jQuery中prev()方法用法实例
Jan 08 Javascript
arguments对象验证函数的参数是否合法
Jun 26 Javascript
jQuery+CSS实现滑动的标签分栏切换效果
Dec 17 Javascript
JavaScript通过改变文字透明度实现的文字闪烁效果实例
Apr 27 Javascript
AngularJs 终极购物车(实例讲解)
Nov 08 Javascript
浅谈Webpack核心模块tapable解析
Sep 11 Javascript
JS学习笔记之原型链和利用原型实现继承详解
May 29 Javascript
解析JS在获取当前月的最后一天遇到的坑
Aug 30 Javascript
vue el-table实现行内编辑功能
Dec 11 Javascript
canvas实现贪食蛇的实践
Vue自定义铃声提示音组件的实现
Jan 22 #Vue.js
JavaScript实例 ODO List分析
Jan 22 #Javascript
JavaScript ES6的函数拓展
Jan 18 #Javascript
Vue提供的三种调试方式你知道吗
Jan 18 #Vue.js
详解Vue项目的打包方式(生成dist文件)
Jan 18 #Vue.js
html5调用摄像头截图功能
Jan 18 #Javascript
You might like
Server.HTMLEncode让代码在页面里显示为源代码
2013/12/08 PHP
Laravel与CI框架中截取字符串函数
2016/05/08 PHP
PHP在linux上执行外部命令的方法
2017/02/06 PHP
PHP有序表查找之二分查找(折半查找)算法示例
2018/02/09 PHP
基于jquery的下拉框改变动态添加和删除表格实现代码
2020/09/12 Javascript
33个优秀的jQuery 教程分享(幻灯片、动画菜单)
2011/07/08 Javascript
JS 操作符整理[推荐收藏]
2011/11/15 Javascript
Javascript 多浏览器兼容总结(实战经验)
2013/10/30 Javascript
javaScript对文字按照拼音排序实现代码
2013/12/27 Javascript
jQuery实现渐变弹出层和弹出菜单的方法
2015/02/20 Javascript
jquery实现公告翻滚效果
2015/02/27 Javascript
nodejs中实现sleep功能实例
2015/03/24 NodeJs
JavaScript实现窗口抖动效果
2016/10/19 Javascript
JS对象序列化成json数据和json数据转化为JS对象的代码
2017/08/23 Javascript
Node.js上传文件功能之服务端如何获取文件上传进度
2018/02/05 Javascript
VUE脚手架的下载和配置步骤详解
2019/04/01 Javascript
vue实现多条件和模糊搜索功能
2019/05/28 Javascript
使用Python的Scrapy框架编写web爬虫的简单示例
2015/04/17 Python
Python的Django框架中从url中捕捉文本的方法
2015/07/20 Python
Python学习小技巧之列表项的拼接
2017/05/20 Python
Python使用matplotlib实现绘制自定义图形功能示例
2018/01/18 Python
Linux(Redhat)安装python3.6虚拟环境(推荐)
2018/05/05 Python
Django配置文件代码说明
2019/12/04 Python
使用pyqt5 tablewidget 单元格设置正则表达式
2019/12/13 Python
30行Python代码实现高分辨率图像导航的方法
2020/05/22 Python
HTML5 Canvas阴影使用方法实例演示
2013/08/02 HTML / CSS
摩托车和ATV零件、配件和服装的首选在线零售商:MotoSport
2017/12/22 全球购物
Wallis官网:英国女装零售商
2020/01/21 全球购物
竞选团支书演讲稿
2014/04/28 职场文书
给学校的建议书范文
2014/05/15 职场文书
优秀大学生自荐信
2014/06/09 职场文书
IT工程师岗位职责
2014/07/04 职场文书
求职导师推荐信范文
2015/03/27 职场文书
志愿服务心得体会
2016/01/15 职场文书
MySQL三种方式实现递归查询
2022/04/18 MySQL
Python中的matplotlib绘制百分比堆叠柱状图,并为每一个类别设置不同的填充图案
2022/04/20 Python