ES6新特性五:Set与Map的数据结构实例分析
发布时间 - 2026-01-11 00:45:37 点击率:次本文实例讲述了ES6新特性五之Set与Map的数据结构。分享给大家供大家参考,具体如下:

1. Set
① 定义:它类似于数组,但是成员的值都是唯一的,没有重复的值。Set本身是一个构造函数,用来生成Set数据结构。
var s = new Set();
[2,3,5,4,5,2,2].map(x => s.add(x))
console.log(s); //Set { 2, 3, 5, 4 }
② 属性和方法
Set结构有以下属性。
Set.prototype.constructor:构造函数,默认就是Set函数。
Set.prototype.size:返回Set的成员总数。
Set数据结构有以下方法。
add(value):添加某个值,返回Set结构本身。
delete(value):删除某个值,返回一个布尔值,表示删除是否成功。
has(value):返回一个布尔值,表示该值是否为Set的成员。
clear():清除所有成员,没有返回值。
var s = new Set(); s.add(1).add(2).add(2); // 注意2被加入了两次 console.log(s.size) // 2 console.log(s.has(1)) // true console.log(s.has(2)) // true console.log(s.has(3)) // false console.log(s.delete(2)); console.log(s.has(2)) // false
③ Array.from方法可以将Set结构转为数组
var items = new Set([1, 2, 3, 4, 5]);
var arr = Array.from(items);
//运用: 去除数组中重复元素的方法
var array = [1,2,3,2,3,4];
function fun(array) {
return Array.from(new Set(array));
}
console.log(fun(array));//[ 1, 2, 3, 4 ]
④ Set结构有一个values方法,返回一个遍历器。
var s = new Set([1, 2, 3, 4, 5]);
console.log(s.values());//SetIterator { 1, 2, 3, 4, 5 }
//Set结构的默认遍历器就是它的values方法
console.log(Set.prototype[Symbol.iterator] === Set.prototype.values)//true
//所以遍历可以直接使用 for...of
for (let x of s) {
console.log(x);
}
//由于扩展运算符(...)内部使用for...of循环,将Set转化为数组。
var arr = [...s];
console.log(arr);//[ 1, 2, 3, 4, 5 ]
⑤ Set结构的foreach方法
var set = new Set([1, 2, 3]);
set.forEach(function(value,key){
console.log(value);
});
⑥ Set结构也有keys和entries方法,这时每个值的键名就是键值。
let set = new Set(['red', 'green', 'blue']);
for ( let item of set.keys() ){
console.log(item);
}
// red
// green
// blue
for ( let [key, value] of set.entries() ){
console.log(key, value);
}
// red, red
// green, green
// blue, blue
⑦ 数组的map和filter方法的运用
map(x){}: 遍历数组,对每一元素进行处理,返回处理后的数组。
filter(x){}: 遍历数组,对每一个元素进行校验,返回含有通过校验元素的数组。
var set = new Set([1, 2, 3]);
set = new Set([...set].map(x => x * 2));
console.log(set);//返回Set结构:{2, 4, 6}
var set = new Set([1, 2, 3, 4, 5]);
set = new Set([...set].filter(x => (x % 2) == 0));
console.log(set);// 返回Set结构:{2, 4}
2. Map
① 原因:JavaScript的对象,本质上是键值对的集合,但是只能用字符串当作键。
② 定义:它类似于对象,也是键值对的集合,但是“键”的范围不限于字符串,各种类型的值(包括对象)都可以当作键。
③ 属性和方法
size:返回成员总数。
set(key, value):设置key所对应的键值,然后返回整个Map结构。如果key已经有值,则键值会被更新,否则就新生成该键。
get(key):读取key对应的键值,如果找不到key,返回undefined。
has(key):返回一个布尔值,表示某个键是否在Map数据结构中。
delete(key):删除某个键,返回true。如果删除失败,返回false。
clear():清除所有成员,没有返回值。
④ 与set 相同 可以接受数组参数创建map,但数组的元素是一个个代表键值对的数组构成。
var map = new Map(); var map1 = new Map([["name", "张三"], ["title", "Author"]]); console.log(map1.size)//2
⑤ 只有对同一个对象的引用,Map结构才将其视为同一个键,只要内存地址不一样,就视为两个键。
var map = new Map(); map.set(['a'], 555); console.log(map.get(['a'])) // undefined var k1 = ['a']; //虽然值相同,但这是一个新的值,内存地址不一样,new 的 var k2 = ['a']; map.set(k1, 111); map.set(k2, 222);
⑥ 遍历
Map结构的默认遍历器接口(Symbol.iterator属性),就是entries方法。
keys():返回键名的遍历器。
values():返回键值的遍历器。
entries():返回所有成员的遍历器。
console.log(Map[Symbol.iterator] === Map.entries)//true let map = new Map([[1, 'one'], [2, 'two'], [3, 'three']]); console.log([...map.keys()]);//[ 1, 2, 3 ] console.log([...map.values()]);//[ 'one', 'two', 'three' ] console.log([...map.entries()]);//[ [ 1, 'one' ], [ 2, 'two' ], [ 3, 'three' ] ] console.log([...map]);[ [ 1, 'one' ], [ 2, 'two' ], [ 3, 'three' ] ]
⑦Map还有一个forEach方法,进行遍历。
⑧与set相同,map可以结合数组的map方法、filter方法,可以实现Map的遍历和过滤。
希望本文所述对大家ECMAScript程序设计有所帮助。
# ES6
# 新特性
# Set
# Map
# 数据结构
# ES6学习笔记之map、set与数组、对象的对比
# ES6中Set和Map用法实例详解
# 一文搞懂ES6中的Map和Set
# 详解ES6中的Map与Set集合
# 详解ES6中的 Set Map 数据结构学习总结
# ES6学习笔记之Set和Map数据结构详解
# ES6基础语法之Map和Set对象
# 遍历
# 键值
# 是一个
# 类似于
# 布尔值
# 返回值
# 也有
# 键名
# 找不到
# 两次
# 将其
# 给大家
# 还有一个
# 可以直接
# 但这
# 可以实现
# 转化为
# 只能用
# 所述
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何生成腾讯云建站专用兑换码?
Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】
常州企业网站制作公司,全国继续教育网怎么登录?
EditPlus中的正则表达式 实战(2)
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
高防服务器:AI智能防御DDoS攻击与数据安全保障
如何用狗爹虚拟主机快速搭建网站?
JavaScript如何实现音频处理_Web Audio API如何工作?
如何快速辨别茅台真假?关键步骤解析
Laravel如何处理CORS跨域请求?(配置示例)
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程
C++用Dijkstra(迪杰斯特拉)算法求最短路径
英语简历制作免费网站推荐,如何将简历翻译成英文?
Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】
图册素材网站设计制作软件,图册的导出方式有几种?
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程
简单实现Android验证码
Laravel如何生成URL和重定向?(路由助手函数)
Python自然语言搜索引擎项目教程_倒排索引查询优化案例
在线制作视频的网站有哪些,电脑如何制作视频短片?
Google浏览器为什么这么卡 Google浏览器提速优化设置步骤【方法】
大学网站设计制作软件有哪些,如何将网站制作成自己app?
Python正则表达式进阶教程_复杂匹配与分组替换解析
Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】
详解Huffman编码算法之Java实现
香港服务器租用每月最低只需15元?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
Android 常见的图片加载框架详细介绍
Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】
JavaScript如何实现类型判断_typeof和instanceof有什么区别
高防服务器租用指南:配置选择与快速部署攻略
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
如何用好域名打造高点击率的自主建站?
Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】
html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】
Laravel如何处理异常和错误?(Handler示例)
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
UC浏览器如何设置启动页 UC浏览器启动页设置方法
浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】
如何挑选优质建站一级代理提升网站排名?
Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID
在Oracle关闭情况下如何修改spfile的参数
网站页面设计需要考虑到这些问题
千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】
如何有效防御Web建站篡改攻击?
如何用腾讯建站主机快速创建免费网站?
如何用VPS主机快速搭建个人网站?
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?

