国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

詳解ES6中的 Set Map 數(shù)據(jù)結構學習總結

2024-05-06 15:28:11
字體:
供稿:網(wǎng)友

ES6中的 Set 數(shù)據(jù)結構

ES6 新增了一種 Set 數(shù)據(jù)結構。它類似數(shù)組。 最重要的一點是 Set中的結構成員沒有重復的, 可用這點 一行代碼實現(xiàn)數(shù)組去重。 Set 本身是一個構造函數(shù)。通過 new Set() 來創(chuàng)建Set結構。

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

通過new Set創(chuàng)建一個Set結構。 forEach 遍歷arr1數(shù)組。把每一項通過Set.prototype.add 方法向Set結構中添加成員。

Set 也可以接受一個數(shù)組作為參數(shù)。

  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() 創(chuàng)建 Set 數(shù)據(jù)結構時, 將一個數(shù)組作為它的參數(shù)。最后通過 for of 遍歷 set2。因為 結構成員沒有重復, 所以打印 1 2 3 4 5

Set 接受的參數(shù)不會進行 類型轉(zhuǎn)換 , new Set(5, '5') 這完全是兩個值。

Set 實現(xiàn)數(shù)組去重

  // 方法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() 中傳入一個數(shù)組, 利用 Set結構成員都是唯一的特性, 最后通過擴展運算符..., 或者ES6提供的一種將類數(shù)組轉(zhuǎn)換為數(shù)組的方法 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() 鍵值對的遍歷器,以數(shù)組形式返回
  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()沒有區(qū)別。entries 遍歷返回的是數(shù)組, 分別是keys() values()結果。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持錯新站長站。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 淳化县| 井冈山市| 夏邑县| 贞丰县| 莆田市| 富阳市| 博乐市| 孟州市| 当雄县| 新余市| 大渡口区| 永登县| 临湘市| 大石桥市| 共和县| 台东县| 边坝县| 靖远县| 通海县| 泰宁县| 阿勒泰市| 娱乐| 绩溪县| 大姚县| 菏泽市| 昌宁县| 新源县| 武邑县| 江山市| 泸州市| 北京市| 无极县| 宁晋县| 盈江县| 兴安县| 通河县| 罗甸县| 横山县| 舒兰市| 金华市| 于田县|