欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ES6中Set和Map數(shù)據(jù)結(jié)構(gòu)的簡單講解

 更新時間:2022年08月21日 08:13:08   作者:RiemannHypothesis  
大家心里是否產(chǎn)生過這樣的疑問,JS中既然已經(jīng)有對象這種數(shù)據(jù)結(jié)構(gòu),我們?yōu)槭裁催€要再單獨去使用Set或者Map呢?下面這篇文章主要給大家介紹了關(guān)于ES6中Set和Map數(shù)據(jù)結(jié)構(gòu)的相關(guān)資料,需要的朋友可以參考下

Set

ES6 提供了新的數(shù)據(jù)結(jié)構(gòu) Set。它類似于數(shù)組,但是成員的值都是唯一的,沒有重復(fù)的值。 Set本身是一個構(gòu)造函數(shù),用來生成 Set 數(shù)據(jù)結(jié)構(gòu)。

const s = new Set();

[2, 3, 5, 4, 5, 2, 2].forEach(x => s.add(x));

for (let i of s) {
  console.log(i);
}
// 2 3 5 4

上面代碼通過add()方法向 Set 結(jié)構(gòu)加入成員,結(jié)果表明 Set 結(jié)構(gòu)不會添加重復(fù)的值。

去除數(shù)組的重復(fù)成員

[...new Set('ababbc')].join('')
// "abc"

向 Set 加入值的時候,不會發(fā)生類型轉(zhuǎn)換,所以5和"5"是兩個不同的值。Set 內(nèi)部判斷兩個值是否不同,使用的算法叫做“Same-value-zero equality”,它類似于精確相等運算符(===),主要的區(qū)別是向 Set 加入值時認為NaN等于自身,而精確相等運算符認為NaN不等于自身。

Set 實例的屬性和方法 Set 結(jié)構(gòu)的實例有以下屬性。

Set.prototype.constructor:構(gòu)造函數(shù),默認就是Set函數(shù)。
Set.prototype.size:返回Set實例的成員總數(shù)。

Set 實例的方法分為兩大類:操作方法(用于操作數(shù)據(jù))和遍歷方法(用于遍歷成員)。下面先介紹四個操作方法。

Set.prototype.add(value):添加某個值,返回 Set 結(jié)構(gòu)本身。
Set.prototype.delete(value):刪除某個值,返回一個布爾值,表示刪除是否成功。
Set.prototype.has(value):返回一個布爾值,表示該值是否為Set的成員。
Set.prototype.clear():清除所有成員,沒有返回值。

s.add(1).add(2).add(2);
// 注意2被加入了兩次

s.size // 2

s.has(1) // true
s.has(2) // true
s.has(3) // false

s.delete(2);
s.has(2) // false

Array.from方法可以將 Set 結(jié)構(gòu)轉(zhuǎn)為數(shù)組。

const items = new Set([1, 2, 3, 4, 5]);
const array = Array.from(items);

這就提供了去除數(shù)組重復(fù)成員的另一種方法。

function dedupe(array) {
  return Array.from(new Set(array));
}

dedupe([1, 1, 2, 3]) // [1, 2, 3]

遍歷操作

Set 結(jié)構(gòu)的實例有四個遍歷方法,可以用于遍歷成員。

Set.prototype.keys():返回鍵名的遍歷器
Set.prototype.values():返回鍵值的遍歷器
Set.prototype.entries():返回鍵值對的遍歷器
Set.prototype.forEach():使用回調(diào)函數(shù)遍歷每個成員
需要特別指出的是,Set的遍歷順序就是插入順序。這個特性有時非常有用,比如使用 Set 保存一個回調(diào)函數(shù)列表,調(diào)用時就能保證按照添加順序調(diào)用。

附:應(yīng)用場景

1.數(shù)組去重

var arr = [1, 2, 3, undefined,undefined,null,null, NaN, 1, 2, 3, NaN],
    set = new Set(arr);
console.log([...set]); 

2. 數(shù)組去重后的實現(xiàn)映射數(shù)組

set實例本身沒有map,filter等數(shù)組屬性

let set = new Set([1,2,3,4,5,6,7]);
let set2 = new Set([...set].map(value => value * 2));

let set = new Set([1,2,3]);
let set1 = new Set(Array.from(set, vlaue=>value * 2));

數(shù)組去重后,過濾返回新的數(shù)組

let set = new Set([1,2,3,4,5,6,7,1,2,3]);
let set2 = new Set([...set].filter(x => (x%2) == 0));

Map

JavaScript 的對象(Object),本質(zhì)上是鍵值對的集合(Hash 結(jié)構(gòu)),但是傳統(tǒng)上只能用字符串當作鍵。這給它的使用帶來了很大的限制。

const map = new Map([
  ['name', '張三'],
  ['title', 'Author']
]);

map.size // 2
map.has('name') // true
map.get('name') // "張三"
map.has('title') // true
map.get('title') // "Author"

和Set 對比

Map.prototype上的clear()、has()、size、delete()方法與Set.prototype上相同;唯一不同的是,Set是不存在鍵名的,鍵值與鍵名相同,所以沒有g(shù)et和set的方法,只有add方法;而Map具有鍵名和鍵值,所以對應(yīng)set和get方法;

總結(jié)

到此這篇關(guān)于ES6中Set和Map數(shù)據(jù)結(jié)構(gòu)的文章就介紹到這了,更多相關(guān)ES6 Set和Map數(shù)據(jù)結(jié)構(gòu)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JS腳本實現(xiàn)動態(tài)給標簽控件添加事件的方法

    JS腳本實現(xiàn)動態(tài)給標簽控件添加事件的方法

    這篇文章主要介紹了JS腳本實現(xiàn)動態(tài)給標簽控件添加事件的方法,結(jié)合實例形式分析了javascript添加事件監(jiān)聽的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2016-06-06
  • 網(wǎng)頁防止tab鍵的使用快速解決方法

    網(wǎng)頁防止tab鍵的使用快速解決方法

    在彈出層后,tab鍵還可以在目頁中操作,這回導致腳本錯誤。那么我們?nèi)绻苊膺@種情況呢?下面小編就為大家介紹一下如何解決這個問題
    2013-11-11
  • 用YUI做了個標簽瀏覽效果

    用YUI做了個標簽瀏覽效果

    用YUI做了個標簽瀏覽效果...
    2007-02-02
  • 深入了解Javascript的事件循環(huán)機制

    深入了解Javascript的事件循環(huán)機制

    單線程的同步等待極大影響效率,任務(wù)不得不一個一個等待執(zhí)行,對于網(wǎng)頁應(yīng)用是無法接受的。所以Javascript使用事件循環(huán)機制來解決異步任務(wù)的問題。本文就來講講Javascript的事件循環(huán)機制,希望對你有所幫助
    2022-09-09
  • 一文搞懂JavaScript中最難理解概念之一的閉包

    一文搞懂JavaScript中最難理解概念之一的閉包

    閉包常常被譽為JavaScript中最難理解的概念之一,這篇文章就來帶大家深入了解一下JavaScript中閉包的概念、實現(xiàn)與應(yīng)用,需要的可以參考一下
    2023-04-04
  • JavaScript實現(xiàn)點擊按鈕直接打印

    JavaScript實現(xiàn)點擊按鈕直接打印

    很多網(wǎng)站都有此功能,當瀏覽到底部時都會有一個打印按鈕,點擊打印按鈕就可以完成打印功能,功能非常不錯,人性化,下面通過本文給大家介紹JavaScript實現(xiàn)點擊按鈕就打印的代碼,需要的朋友參考下
    2016-01-01
  • 微信小程序 高德地圖路線規(guī)劃實現(xiàn)過程詳解

    微信小程序 高德地圖路線規(guī)劃實現(xiàn)過程詳解

    這篇文章主要介紹了微信小程序 路線規(guī)劃實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • javascript 讀取XML數(shù)據(jù),在頁面中展現(xiàn)、編輯、保存的實現(xiàn)

    javascript 讀取XML數(shù)據(jù),在頁面中展現(xiàn)、編輯、保存的實現(xiàn)

    最近需要做這樣一個需求,數(shù)據(jù)保存在XML里,在頁面上通過表格顯示其內(nèi)容,可以修改內(nèi)容,再保存到XML。下面把做這個東西的過程記錄下來,做個筆記,也給需要的人一些幫助。
    2009-10-10
  • js設(shè)置隨機切換背景圖片的簡單實例

    js設(shè)置隨機切換背景圖片的簡單實例

    下面小編就為大家?guī)硪黄猨s設(shè)置隨機切換背景圖片的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 微信小程序map地圖使用方法詳解

    微信小程序map地圖使用方法詳解

    這篇文章主要為大家詳細介紹了微信小程序map地圖使用的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10

最新評論