全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

ES6新特性五:Set与Map的数据结构实例分析

本文实例讲述了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对象  # 遍历  # 键值  # 是一个  # 类似于  # 布尔值  # 返回值  # 也有  # 键名  # 找不到  # 两次  # 将其  # 给大家  # 还有一个  # 可以直接  # 但这  # 可以实现  # 转化为  # 只能用  # 所述 


相关文章: 淘宝制作网站有哪些,淘宝网官网主页?  建站之星后台管理如何实现高效配置?  如何快速生成ASP一键建站模板并优化安全性?  网站代码制作软件有哪些,如何生成自己网站的代码?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  行程制作网站有哪些,第三方机票电子行程单怎么开?  手机网站制作与建设方案,手机网站如何建设?  如何解决VPS建站LNMP环境配置常见问题?  制作农业网站的软件,比较好的农业网站推荐一下?  公众号网站制作网页,微信公众号怎么制作?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  h5网站制作工具有哪些,h5页面制作工具有哪些?  想学网站制作怎么学,建立一个网站要花费多少?  焦点电影公司作品,电影焦点结局是什么?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  香港服务器部署网站为何提示未备案?  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  如何在万网ECS上快速搭建专属网站?  如何用AWS免费套餐快速搭建高效网站?  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  教育培训网站制作流程,请问edu教育网站的域名怎么申请?  如何在阿里云域名上完成建站全流程?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  专业公司网站制作公司,用什么语言做企业网站比较好?  如何选择高效可靠的多用户建站源码资源?  制作公司内部网站有哪些,内网如何建网站?  家具网站制作软件,家具厂怎么跑业务?  如何配置FTP站点权限与安全设置?  建站之星如何一键生成手机站?  如何在万网自助建站平台快速创建网站?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  南宁网站建设制作定制,南宁网站建设可以定制吗?  音乐网站服务器如何优化API响应速度?  如何用已有域名快速搭建网站?  如何通过山东自助建站平台快速注册域名?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  网站制作价目表怎么做,珍爱网婚介费用多少?  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  如何快速生成专业多端适配建站电话?  宝塔建站助手安装配置与建站模板使用全流程解析  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  XML的“混合内容”是什么 怎么用DTD或XSD定义  深圳企业网站制作设计,在深圳如何网上全流程注册公司?  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何通过西部建站助手安装IIS服务器? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。