最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-27 22:04:19
文档

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

详解ES6中的 Set Map 数据结构学习总结:ES6中的 Set 数据结构 ES6 新增了一种 Set 数据结构。它类似数组。 最重要的一点是 Set中的结构成员没有重复的, 可用这点 一行代码实现数组去重。 Set 本身是一个构造函数。通过 new Set() 来创建Set结构。 let arr1 = ['Hello', '
推荐度:
导读详解ES6中的 Set Map 数据结构学习总结:ES6中的 Set 数据结构 ES6 新增了一种 Set 数据结构。它类似数组。 最重要的一点是 Set中的结构成员没有重复的, 可用这点 一行代码实现数组去重。 Set 本身是一个构造函数。通过 new Set() 来创建Set结构。 let arr1 = ['Hello', '

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()结果。

    声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

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

    详解ES6中的 Set Map 数据结构学习总结:ES6中的 Set 数据结构 ES6 新增了一种 Set 数据结构。它类似数组。 最重要的一点是 Set中的结构成员没有重复的, 可用这点 一行代码实现数组去重。 Set 本身是一个构造函数。通过 new Set() 来创建Set结构。 let arr1 = ['Hello', '
    推荐度:
    标签: 的数据 se 数据
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top