详解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 相关文章推荐
XML+XSL 与 HTML 两种方案的结合
Apr 22 Javascript
解javascript 混淆加密收藏
Jan 16 Javascript
jquery图片上下tab切换效果
Mar 18 Javascript
浅谈JavaScript中setInterval和setTimeout的使用问题
Aug 01 Javascript
js验证身份证号有效性并提示对应信息
Oct 19 Javascript
JavaScript进阶练习及简单实例分析
Jun 03 Javascript
Angular2中Bootstrap界面库ng-bootstrap详解
Oct 18 Javascript
Vue组件模板形式实现对象数组数据循环为树形结构(实例代码)
Jul 31 Javascript
bootstrap时间插件daterangepicker使用详解
Oct 19 Javascript
从0到1构建vueSSR项目之node以及vue-cli3的配置
Mar 07 Javascript
Node.js Windows Binary二进制文件安装方法
May 16 Javascript
JavaScript交换变量常用4种方法解析
Sep 02 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
NT IIS下用ODBC连接数据库
2006/10/09 PHP
PHP系列学习之日期函数使用介绍
2012/08/18 PHP
PHP面向对象程序设计之类常量用法实例
2014/08/20 PHP
php中mkdir函数用法实例分析
2014/11/15 PHP
php简单获取目录列表的方法
2015/03/24 PHP
详解WordPress开发中wp_title()函数的用法
2016/01/07 PHP
PHP解压tar.gz格式文件的方法
2016/02/14 PHP
PHP构造函数与析构函数用法示例
2016/09/28 PHP
PHP二维数组去重算法
2016/12/17 PHP
php正则判断是否为合法身份证号的方法
2017/03/16 PHP
基于jQuery的简单的列表导航菜单
2011/03/02 Javascript
基于jquery的合并table相同单元格的插件(精简版)
2011/04/05 Javascript
jQuery扁平化风格下拉框美化插件FancySelect使用指南
2015/02/10 Javascript
详解JavaScript中的blink()方法的使用
2015/06/08 Javascript
AngularJS中过滤器的使用与自定义实例代码
2016/09/17 Javascript
浅谈angularjs module返回对象的坑(推荐)
2016/10/21 Javascript
第一次接触神奇的前端框架vue.js
2016/12/01 Javascript
js常用的继承--组合式继承
2017/03/06 Javascript
vscode中vue-cli项目es-lint的配置方法
2018/07/30 Javascript
angularJs中orderBy筛选以及filter过滤数据的方法
2018/09/30 Javascript
浅谈JS中this在各个场景下的指向
2019/08/14 Javascript
vue绑定class的三种方法
2020/12/24 Vue.js
关于element的表单组件整理笔记
2021/02/05 Javascript
[01:33]DOTA2上海特级锦标赛 LIQUID战队完整宣传片
2016/03/16 DOTA
Python中正则表达式的用法实例汇总
2014/08/18 Python
Python自定义类的数组排序实现代码
2016/08/28 Python
对python3中, print横向输出的方法详解
2019/01/28 Python
基于python-pptx库中文文档及使用详解
2020/02/14 Python
Fashion Eyewear美国:英国线上设计师眼镜和太阳镜的零售商
2016/08/15 全球购物
Bata印度官网:源自欧洲舒适鞋履品牌
2020/01/30 全球购物
桥梁与隧道工程专业本科生求职信
2013/10/08 职场文书
《太阳》教学反思
2014/02/21 职场文书
2014年党风廉政工作总结
2014/12/03 职场文书
银行反洗钱宣传活动总结
2015/05/08 职场文书
三好学生评选事迹材料(2016精选版)
2016/02/25 职场文书
vue递归实现树形组件
2022/07/15 Vue.js