千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > js去重怎么操作

js去重怎么操作

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-08-11 16:23:11 1691742191

在JavaScript中,去重是指從一個(gè)數(shù)組或者集合中移除重復(fù)的元素,只保留唯一的值。下面我將為你介紹幾種常見的去重操作方法。

方法一:使用Set

使用Set是一種簡單且高效的去重方法。Set是ES6中引入的一種新的數(shù)據(jù)結(jié)構(gòu),它只能存儲(chǔ)唯一的值。

const arr = [1, 2, 2, 3, 4, 4, 5];

const uniqueArr = [...new Set(arr)];

console.log(uniqueArr); // [1, 2, 3, 4, 5]

方法二:使用filter

使用filter方法結(jié)合indexOf可以實(shí)現(xiàn)數(shù)組去重。

const arr = [1, 2, 2, 3, 4, 4, 5];

const uniqueArr = arr.filter((item, index) => {

return arr.indexOf(item) === index;

});

console.log(uniqueArr); // [1, 2, 3, 4, 5]

方法三:使用reduce

使用reduce方法可以將數(shù)組中的元素逐個(gè)與結(jié)果數(shù)組進(jìn)行比較,如果結(jié)果數(shù)組中不存在該元素,則將其添加到結(jié)果數(shù)組中。

const arr = [1, 2, 2, 3, 4, 4, 5];

const uniqueArr = arr.reduce((prev, cur) => {

if (!prev.includes(cur)) {

prev.push(cur);

}

return prev;

}, []);

console.log(uniqueArr); // [1, 2, 3, 4, 5]

方法四:使用Map

使用Map可以實(shí)現(xiàn)類似Set的去重效果,將數(shù)組中的元素作為Map的鍵,值可以是任意值。

const arr = [1, 2, 2, 3, 4, 4, 5];

const uniqueArr = Array.from(new Map(arr.map(item => [item, item]))).map(item => item[0]);

console.log(uniqueArr); // [1, 2, 3, 4, 5]

方法五:使用遞歸

使用遞歸可以實(shí)現(xiàn)對(duì)多維數(shù)組的去重操作。

function unique(arr) {

const result = [];

arr.forEach(item => {

if (Array.isArray(item)) {

result.push(...unique(item));

} else if (!result.includes(item)) {

result.push(item);

}

});

return result;

const arr = [1, 2, [2, 3], [4, [4, 5]]];

const uniqueArr = unique(arr);

console.log(uniqueArr); // [1, 2, 3, 4, 5]

以上是幾種常見的JavaScript去重操作方法,你可以根據(jù)實(shí)際需求選擇適合的方法來進(jìn)行去重操作。希望對(duì)你有所幫助!

千鋒教育擁有多年IT培訓(xùn)服務(wù)經(jīng)驗(yàn),開設(shè)Java培訓(xùn)、web前端培訓(xùn)、大數(shù)據(jù)培訓(xùn),python培訓(xùn)、軟件測(cè)試培訓(xùn)等課程,采用全程面授高品質(zhì)、高體驗(yàn)教學(xué)模式,擁有國內(nèi)一體化教學(xué)管理及學(xué)員服務(wù),想獲取更多IT技術(shù)干貨請(qǐng)關(guān)注千鋒教育IT培訓(xùn)機(jī)構(gòu)官網(wǎng)。

tags: js去重
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
linux不保存退出命令是什么?

一、基礎(chǔ)概念解析 Linux系統(tǒng)中有多種方式可以用于退出當(dāng)前用戶會(huì)話,其中最常用的是exit和logout命令。這些命令允許用戶安全地結(jié)束當(dāng)前的終端會(huì)...詳情>>

2023-10-16 13:33:05
linux中vi指令是什么意思?

一、VI編輯器的基礎(chǔ)命令模式在命令模式下,用戶可以使用鍵盤快捷鍵進(jìn)行文本和光標(biāo)的導(dǎo)航,如h、j、k和l用于上下左右移動(dòng)。插入模式進(jìn)入插入模式...詳情>>

2023-10-16 13:29:05
git怎么設(shè)置遠(yuǎn)程分支?

1、創(chuàng)建本地分支在設(shè)置遠(yuǎn)程分支之前,您需要先在本地創(chuàng)建一個(gè)分支。這是您開始工作的地方,然后將更改推送到遠(yuǎn)程倉庫。使用以下命令創(chuàng)建并切換...詳情>>

2023-10-16 13:21:15
如何在Gitee上創(chuàng)建新分支?

1.登錄到Gitee首先,打開您的Web瀏覽器并登錄到您的Gitee帳戶。確保您有權(quán)限對(duì)項(xiàng)目進(jìn)行修改,因?yàn)橹挥许?xiàng)目的所有者或具有適當(dāng)權(quán)限的團(tuán)隊(duì)成員才...詳情>>

2023-10-16 13:13:07
idea中怎么配置使用gitlab?

1.安裝Git首先,確保您的計(jì)算機(jī)上安裝了Git。您可以從Git官方網(wǎng)站下載適用于您操作系統(tǒng)的Git版本并進(jìn)行安裝。2.在GitLab上創(chuàng)建項(xiàng)目如果您還沒有...詳情>>

2023-10-16 13:03:03