详解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 文档的编码问题解决
Mar 01 Javascript
JavaScript 权威指南(第四版) 读书笔记
Aug 11 Javascript
去掉gridPanel表头全选框的小例子
Jul 18 Javascript
jQuery中:lt选择器用法实例
Dec 29 Javascript
Javascript URI 解析介绍
Mar 15 Javascript
浅谈JavaScript中null和undefined
Jul 09 Javascript
一种新的javascript对象创建方式Object.create()
Dec 28 Javascript
Chrome不支持showModalDialog模态对话框和无法返回returnValue问题的解决方法
Oct 30 Javascript
JavaScript的六种继承方式(推荐)
Jun 26 Javascript
vue.js动画中的js钩子函数的实现
Jul 06 Javascript
vue 的点击事件获取当前点击的元素方法
Sep 15 Javascript
vue修饰符.capture和.self的区别
Apr 22 Vue.js
小程序实现页面顶部选项卡效果
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游戏编程25个脚本代码
2011/02/08 PHP
Yii实现多数据库主从读写分离的方法
2014/12/29 PHP
php获取Google机器人访问足迹的方法
2015/04/15 PHP
一波PHP中cURL库的常见用法代码示例
2016/05/06 PHP
使用TextRange获取输入框中光标的位置的代码
2007/03/08 Javascript
javascript中的几个运算符
2007/06/29 Javascript
js滚动条回到顶部的代码
2011/12/06 Javascript
Js中的onblur和onfocus事件应用介绍
2013/08/27 Javascript
javascript(js)的小数点乘法除法问题详解
2014/03/07 Javascript
JavaScript函数的4种调用方法详解
2014/04/22 Javascript
jquery果冻抖动效果实现方法
2015/01/15 Javascript
jQuery实现仿新浪微博浮动的消息提示框(可智能定位)
2015/10/10 Javascript
jquery $.trim()去除字符串空格的实现方法【附图例】
2016/03/30 Javascript
JS实现的样式切换功能tableCSS实例
2016/12/30 Javascript
jquery实现转盘抽奖功能
2017/01/06 Javascript
vue.js父组件使用外部对象的方法示例
2017/04/25 Javascript
关于layui表单中按钮自动提交的解决方法
2019/09/09 Javascript
[00:57]林俊杰助阵DOTA2亚洲邀请赛
2015/01/28 DOTA
浅谈python类属性的访问、设置和删除方法
2016/07/25 Python
python利用拉链法实现字典方法示例
2017/03/25 Python
Python算法输出1-9数组形成的结果为100的所有运算式
2017/11/03 Python
Python爬虫设置代理IP的方法(爬虫技巧)
2018/03/04 Python
pytorch构建网络模型的4种方法
2018/04/13 Python
在Python中给Nan值更改为0的方法
2018/10/30 Python
python3 字符串知识点学习笔记
2020/02/08 Python
python实现全排列代码(回溯、深度优先搜索)
2020/02/26 Python
在django中使用post方法时,需要增加csrftoken的例子
2020/03/13 Python
使用python+poco+夜神模拟器进行自动化测试实例
2020/04/23 Python
python matlab库简单用法讲解
2020/12/31 Python
nohup的用法
2014/08/10 面试题
眼镜促销方案
2014/03/15 职场文书
政治学专业毕业生求职信
2014/08/11 职场文书
庆祝国庆节演讲稿2014
2014/09/19 职场文书
工程安全生产协议书
2014/11/21 职场文书
西安大雁塔导游词
2015/02/10 职场文书
Django实现WebSocket在线聊天室功能(channels库)
2021/09/25 Python