详解ES6中的 Set Map 数据结构学习总结


Posted in Javascript onNovember 06, 2018

ES6中的 Set 数据结构

ES6 新增了一种 Set 数据结构。它类似数组。 最重要的一点是 Set中的结构成员没有重复的, 可用这点 一行代码实现数组去重。 Set 本身是一个构造函数。通过 new Set() 来创建Set结构。

let arr1 = ['Hello', 'World', 'ES6']
  let set1 = new Set() 
  arr1.forEach(type => {
    set1.add(type)
  })

通过new Set创建一个Set结构。 forEach 遍历arr1数组。把每一项通过Set.prototype.add 方法向Set结构中添加成员。

Set 也可以接受一个数组作为参数。

let arr2 = [1,2,3,4,1,5,2]
  let set2 = new Set(arr2) 
  for (let type of set2) {
   console.log(type)
  }
  // 1
  // 2
  // 3
  // 4
  // 5

上面的new Set() 创建 Set 数据结构时, 将一个数组作为它的参数。最后通过 for of 遍历 set2。因为 结构成员没有重复, 所以打印 1 2 3 4 5

Set 接受的参数不会进行 类型转换 , new Set(5, '5') 这完全是两个值。

Set 实现数组去重

// 方法1 
  [...new Set([1,2,3,1,2])] // 1 2 3
  
  // 方法2
  Array.from(new Set([1,2,3,1,2])) // 1 2 3

都是通过向 new Set() 中传入一个数组, 利用 Set结构成员都是唯一的特性, 最后通过扩展运算符..., 或者ES6提供的一种将类数组转换为数组的方法 Array.from()。

Set 操作方法

  • Set.prototype.add(value) 向Set结构中添加一名成员, 返回值为Set结构
  • Set.prototype.delete(value) 删除一名成员, 返回值为布尔值。 true成功, false失败
  • Set.prototype.has(value) Set 成员是否存在, true为存在, false为不存在
  • Set.prototype.clear() 清空所有的成员
let arr3 = [7,8,9]
  let set3 = new Set(arr3)
  set3.add(10)
  set3.size() // 4
  set3.delete(8)
  set3.size() // 3
  set3.clear() // 0

Set 遍历方法

  • keys() 键名的遍历器
  • values() 键值的遍历器
  • entries() 键值对的遍历器,以数组形式返回
let arr4 = ['javascript', 'vue', 'node.js', 'typescript']
  let set4 = new Set(arr4) 
  
  // set.keys()
  for (let k of set4.keys()) {
   console.log(k)\
   // javascript
   // vue 
   // node.js
   // typescript
  } 

 // set.values()
 for (ket v of set4.values()) {
  console.log(v)
  // 和上面的set4.keys() 遍历的结果一样
 } 

 // set.entries()
 for (let e of set3.entries()) {
  console.log(e)
  // ['javascript', 'javascript']
  // ['vue', 'vue']
  // ['node.js', 'node.js']
  // ['typescript', 'typescript']
 }

可见, keys()和values() 遍历是一模一样的, 以后遍历使用keys()还是values()没有区别。entries 遍历返回的是数组, 分别是keys() values()结果。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 动态创建VML的方法
Oct 14 Javascript
jQuery的实现原理的模拟代码 -4 重要的扩展函数 extend
Aug 03 Javascript
整理AngularJS中的一些常用指令
Jun 16 Javascript
javascript实现滚动效果的数字时钟实例
Jul 21 Javascript
Angular.JS学习之依赖注入$injector详析
Oct 20 Javascript
深入浅析ES6 Class 中的 super 关键字
Oct 20 Javascript
详解React项目的服务端渲染改造(koa2+webpack3.11)
Mar 19 Javascript
详解用async/await来处理异步
Aug 28 Javascript
vue 关闭浏览器窗口的时候,清空localStorage的数据示例
Nov 06 Javascript
ES6实现图片切换特效代码
Jan 14 Javascript
vue中使用带隐藏文本信息的图片、图片水印的方法
Apr 24 Javascript
解决VUEX的mapState/...mapState等取值问题
Jul 24 Javascript
小程序实现页面顶部选项卡效果
Nov 06 #Javascript
Vue常用的几个指令附完整案例
Nov 06 #Javascript
vue-cli 打包后提交到线上出现 "Uncaught SyntaxError:Unexpected token" 报错
Nov 06 #Javascript
100行代码实现一个vue分页组功能
Nov 06 #Javascript
微信小程序自定义tabBar组件开发详解
Sep 24 #Javascript
Vue递归实现树形菜单方法实例
Nov 06 #Javascript
electron中使用bootstrap的示例代码
Nov 06 #Javascript
You might like
PHP+DBM的同学录程序(3)
2006/10/09 PHP
合并ThinkPHP配置文件以消除代码冗余的实现方法
2014/07/22 PHP
PHP设计模式之装饰器模式实例详解
2018/02/07 PHP
读jQuery之七 判断点击了鼠标哪个键的代码
2011/06/21 Javascript
JavaScript 和 Java 的区别浅析
2013/07/31 Javascript
jquery判断RadioButtonList和RadioButton中是否有选中项示例
2013/09/29 Javascript
js对象内部访问this修饰的成员函数示例
2014/04/27 Javascript
Javascript无参数和有参数类继承问题解决方法
2015/03/02 Javascript
Vue.js学习笔记之 helloworld
2016/08/14 Javascript
vue.js父组件使用外部对象的方法示例
2017/04/25 Javascript
Vue.js学习记录之在元素与template中使用v-if指令实例
2017/06/27 Javascript
angularjs实现的购物金额计算工具示例
2018/05/08 Javascript
vue中动态设置meta标签和title标签的方法
2018/07/11 Javascript
Vue页面跳转动画效果的实现方法
2018/09/23 Javascript
详解Node.js异步处理的各种写法
2019/06/09 Javascript
Python同步遍历多个列表的示例
2019/02/19 Python
Python中的pathlib.Path为什么不继承str详解
2019/06/23 Python
python画图——实现在图上标注上具体数值的方法
2019/07/08 Python
Python 3.8 新功能全解
2019/07/25 Python
tensorflow实现对张量数据的切片操作方式
2020/01/19 Python
Python数据可视化处理库PyEcharts柱状图,饼图,线性图,词云图常用实例详解
2020/02/10 Python
python3定位并识别图片验证码实现自动登录功能
2021/01/29 Python
html5/css3响应式页面开发总结
2018/10/16 HTML / CSS
浅谈HTML5新增和废弃的标签
2019/04/28 HTML / CSS
英语专业毕业生求职信
2014/05/24 职场文书
年终考核实施方案
2014/05/26 职场文书
物流管理专业推荐信
2014/09/06 职场文书
公司领导班子召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
万里长城导游词
2015/01/30 职场文书
军事博物馆观后感
2015/06/05 职场文书
名人传读书笔记
2015/06/26 职场文书
周一给客户的问候语
2015/11/10 职场文书
浅谈Golang 嵌套 interface 的赋值问题
2021/04/29 Golang
SpringBoot整合JWT的入门指南
2021/06/29 Java/Android
不同品牌、不同型号对讲机如何互相通联
2022/02/18 无线电
Win10玩csgo闪退如何解决?Win10玩csgo闪退的解决方法
2022/07/23 数码科技