溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

es6中如何實(shí)現(xiàn)數(shù)組去重

發(fā)布時(shí)間:2022-08-31 09:35:35 來(lái)源:億速云 閱讀:3788 作者:iii 欄目:web開(kāi)發(fā)

這篇“es6中如何實(shí)現(xiàn)數(shù)組去重”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“es6中如何實(shí)現(xiàn)數(shù)組去重”文章吧。

3種實(shí)現(xiàn)方法:1、Set數(shù)據(jù)結(jié)構(gòu)和“Array.from()”去重,語(yǔ)法“Array.from(new Set(arr))”;2、Set數(shù)據(jù)結(jié)構(gòu)和擴(kuò)展運(yùn)算符“...”去重,語(yǔ)法“[...new Set(arr)]”;3、filter()和indexOf()過(guò)濾,語(yǔ)法“arr.filter((it,in)=>{return arr.indexOf(it,0)===in;});”。

本教程操作環(huán)境:windows7系統(tǒng)、ECMAScript 6版、Dell G3電腦。

ES6數(shù)組去重的5種方法

1、Set數(shù)據(jù)結(jié)構(gòu)和Array.from()去重

  • Set是ES6新提供的數(shù)據(jù)結(jié)構(gòu),類似于數(shù)組,但是本身沒(méi)有重復(fù)值。利用這一特性,我們可以將數(shù)組轉(zhuǎn)為Set類型進(jìn)行去重,然后使用Array.from方法將其再轉(zhuǎn)為數(shù)組。

  • Array.from方法用于將兩類對(duì)象轉(zhuǎn)為真正的數(shù)組:類似數(shù)組的對(duì)象(array-like object)和可遍歷(iterable)的對(duì)象(包括 ES6 新增的數(shù)據(jù)結(jié)構(gòu) Set 和 Map)。

實(shí)現(xiàn)思想:

  • 將數(shù)組轉(zhuǎn)為set集合去重后,使用Array.from方法將集合轉(zhuǎn)為數(shù)組

語(yǔ)法:

Array.from(new Set(arr))

示例:

let arr=[1,2,3,3,2,"1",0,undefined,undefined];
let newArr=Array.from(new Set(arr));
console.log(newArr);

es6中如何實(shí)現(xiàn)數(shù)組去重

2、Set數(shù)據(jù)結(jié)構(gòu)和擴(kuò)展運(yùn)算符“...”去重

  • 擴(kuò)展運(yùn)算符是ES6中引入的,將可迭代對(duì)象展開(kāi)到其單獨(dú)的元素中,所謂的可迭代對(duì)象就是任何能用for of循環(huán)進(jìn)行遍歷的對(duì)象,例如:數(shù)組、字符串、Map 、Set 、DOM節(jié)點(diǎn)等。

實(shí)現(xiàn)思想:

  • 將數(shù)組轉(zhuǎn)為set集合去重后,使用擴(kuò)展運(yùn)算符…將集合展開(kāi)到數(shù)組中,將集合轉(zhuǎn)為數(shù)組

語(yǔ)法:

[...new Set(arr)]

示例:

let arr=[1,2,3,3,2,"1",0,1,2];
let newArr=[...new Set(arr)];
console.log(newArr);

es6中如何實(shí)現(xiàn)數(shù)組去重

3、利用數(shù)組的 filter+indexOf方法去重

filter() 方法創(chuàng)建一個(gè)新的數(shù)組,新數(shù)組中的元素是通過(guò)檢查指定數(shù)組中符合條件的所有元素。

indexOf方法返回指定元素在數(shù)組中的第一個(gè)索引(index), 如果沒(méi)有則返回 -1

示例:

var arr=[1, 2, 3, 2, 3];
var newArr = arr.filter((item,index)=> {
  return arr.indexOf(item,0) === index;
});
console.log(newArr);

es6中如何實(shí)現(xiàn)數(shù)組去重

所以這里的 arr 數(shù)組中的每個(gè)元素通過(guò) indexOf() 方法返回的索引值分別是 0 1 2 1 2

arr.forEach(item => console.log(arr.indexOf(item))); // 0 1 2 1 2

可以通過(guò) indexOf 來(lái)實(shí)現(xiàn)去重,比如 arr 中的第四個(gè)元素 2 通過(guò) indexOf 返回的是索引是 1, 但是它當(dāng)前的 index 下標(biāo)是 3,不相等,說(shuō)明當(dāng)前的這個(gè) 2 元素在之前出現(xiàn)過(guò), 所以應(yīng)該把它過(guò)濾掉。

以上就是關(guān)于“es6中如何實(shí)現(xiàn)數(shù)組去重”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

es6
AI