ES6之set-map数据结构的实例详解
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了ES6之set-map数据结构的实例详解,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1974字,纯文字阅读大概需要3分钟。
内容图文
![ES6之set-map数据结构的实例详解](/upload/InfoBanner/zyjiaocheng/302/da57ecf9fc5c4227ba5a55afa7271272.jpg)
{ let list = new Set(); list.add(5); list.add(7); console.log('size',list.size); }
还有另外一种初始化的方式(通过直接把数组传递进去)
{ let arr = [1,2,3,4,5]; let list = new Set(arr); console.log('size',list.size); }
set里面的元素不可以重复(可以通过set的这个特性进行数组去重,注意:转化过程中不会进行 数据类型转化)
{ let list = new Set(); list.add(1); list.add(2); list.add(1);//不会报错 只是不会生效 console.log('list',list); let arr=[1,2,3,1,'2']; let list2=new Set(arr); console.log('unique',list2); }
set的一些方法(add ,delete,clear,has)
{ let arr=['add','delete','clear','has']; let list=new Set(arr); console.log('has',list.has('add'));//是否包含 console.log('delete',list.delete('add'),list);//清空 list.clear(); console.log('list',list); }
set的遍历(keys和values返回的都是set里面的值)
{ let arr=['add','delete','clear','has']; let list=new Set(arr); for(let key of list.keys()){ console.log('keys',key); } for(let value of list.values()){ console.log('value',value); } for(let [key,value] of list.entries()){ console.log('entries',key,value); } list.forEach(function(item){console.log(item);}) }
WeakSet(里面的元素只能是对象,并且不会检测所添加的对象是否在别处引用,没有size clear 不支持遍历)
{ let weakList=new WeakSet(); let arg={}; weakList.add(arg); // weakList.add(2); console.log('weakList',weakList); }
二、Map数据结构(Map是通过key/value进行设置的,所以设置用set方法,获取使用get方法)
{ let map = new Map(); let arr=['123']; map.set(arr,456); console.log('map',map,map.get(arr)); }
Map的另外一种定义方式(同时size delete clear方法一样)
{ let map = new Map([['a',123],['b',456]]); console.log('map args',map); console.log('size',map.size); console.log('delete',map.delete('a'),map); console.log('clear',map.clear(),map); }
weakMap数据结构(和setMap的特性一致)
{ let weakmap=new WeakMap(); let o={}; weakmap.set(o,123); console.log(weakmap.get(o)); }
以上就是ES6之set-map数据结构的实例详解的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的ES6之set-map数据结构的实例详解全部内容,希望文章能够帮你解决ES6之set-map数据结构的实例详解所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。