阅读 118

ES6 新增Set与Map

前言

  • 上篇了解了ES6新增函数

  • 这篇讲讲新增 Set Map 两种数据结构

Set

  • Set是集合的数据结构

    let a = new Set() 复制代码

    let a = new Set() a.add(1).add(1) // 1只被添加了一次 set不允许有重复元素 复制代码

    let a = new Set() a.add(1).add(2) // {1,2} a.delete(1) // true a // {2} 复制代码

    let a = new Set() a.add(1) // {1} a.has(1) // true 复制代码

    let a = new Set() a.add(1).add(3) // {1,3} a.clear() a // {} 复制代码

    • clear 清除所有元素 没有返回值

    • has 判断元素是否存在set中 返回一个布尔值

    • delete 删除某个元素 返回一个布尔值

    • Set的增删改查方法

    • add 添加某个值 返回Set本身

    • 由一堆无序,相关联,不重复的元素组成的组合

    • 类似数组 所有元素的值是唯一的

    • Set本身就是构造函数 用来生成Set数据结构

  • Set 遍历方法

    let a = new Set([1,2,3]) for(let item of a.keys) {     console.log(item) // 1 2 3 } 复制代码

    let a = new Set([1,2,3]) for(let item of a.values) {     console.log(item) // 1 2 3 } 复制代码

    let a = new Set([1,2,3]) for(let item of a.values) {     console.log(item) // [1,1] [2,2] [3,3] } 复制代码

    let a = new Set([1,2,3]) a.forEach((value,key)=>{console.log(`${key}:${value}`)}) // 1:1 2:2 3:3 复制代码

    let arr =  [1,2,3,3,2,1] let arr2 = [...new Set(arr)] // [1,2,3] 复制代码

    • 扩展运算符和set并用实现数组去重

    • forEach 使用回调函数遍历每个元素

    • entries 返回键值对的遍历器

    • values 返回键值的遍历器

    • keys 返回键名的遍历器

Map

  • 键值对的有序列表 键和值可以是任何类型

    let map = new Map() 复制代码

    • map 本身是构造函数 用来生成map结构

  • map的增删改查

    let map = new Map() map.set(1,2) map.size // 1 复制代码

    let map = new Map() map.set(1,2).set(3,4) //链式写法 复制代码

    let map = new Map() map.set(1,2).set(3,4) // {1=>2,3=>4} map.get(1) // 2 复制代码

    let map = new Map() map.set(1,2) // {1=>2} map.has(1) //true 复制代码

    let map = new Map() map.set(1,2).set(3,4) // {1=>2,3=>4} map.delete(1) //true map // {3=>4} 复制代码

    let map = new Map() map.set(1,2).set(3,4) // {1=>2,3=>4} map.clear map // {} 复制代码

    • clear 清除所有元素 没有返回值

    • delete 删除某个键 返回一个布尔值

    • has 查找某个键是否在当前map中 返回布尔值

    • get 读取key对应的值 如果找不到key 返回undefined

    • set 设置键名与键值 并返回map 如果键名相同 键值则会覆盖

    • size 返回map结构中元素个数

  • Map的遍历

    let map = new Map([     ['a',1],     ['b',2] ]) for(let item of map.keys()) {     console.log(item)  // 'a' 'b' } 复制代码

    let map = new Map([     ['a',1],     ['b',2] ]) for(let item of map.values()) {     console.log(item)  // 1 2 } 复制代码

    let map = new Map([     ['a',1],     ['b',2] ]) for(let item of map.entries()) {     console.log(item)  // ['a',1] ['b',1] } 复制代码

    let map = new Map([     ['a',1],     ['b',2] ]) map.forEach((value,key)=>{     console.log(key,value) }) // a 1 b 2 复制代码

    • forEach 遍历map所有元素

    • entries 返回键值对的遍历器

    • values 返回键值的遍历器

    • keys 返回键名的遍历器

Set与Map的区别

  • 共同点

    • 集合、字典都可以存储不重复的值

  • 不同点

    • 集合是以[值,值]的形式存储元素,字典是以[键,值]的形式存储


作者:vike123
链接:https://juejin.cn/post/7023954136898994206


文章分类
后端
文章标签
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐