千鋒教育-做有情懷、有良心、有品質(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)前位置:首頁(yè)  >  技術(shù)干貨  > js數(shù)組中去除重復(fù)值的幾種方法

js數(shù)組中去除重復(fù)值的幾種方法

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-08-08 17:32:24 1691487144

在JavaScript中,有幾種方法可以從數(shù)組中去除重復(fù)值。下面將介紹其中的幾種常用方法。

方法一:使用Set

使用Set是一種簡(jiǎn)單且高效的方法,它可以幫助我們快速去除數(shù)組中的重復(fù)值。Set是ES6中引入的一種新的數(shù)據(jù)結(jié)構(gòu),它類似于數(shù)組,但是它的成員是唯一的,沒(méi)有重復(fù)值。

`javascript

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

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

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

方法二:使用filter

我們可以使用filter方法結(jié)合indexOf來(lái)過(guò)濾掉數(shù)組中的重復(fù)值。

`javascript

const arr = [1, 2, 3, 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é)果累積到一個(gè)新的數(shù)組中。我們可以使用reduce方法來(lái)去除重復(fù)值。

`javascript

const arr = [1, 2, 3, 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來(lái)去除數(shù)組中的重復(fù)值。Map是一種鍵值對(duì)的集合,其中鍵是唯一的,我們可以利用這個(gè)特性來(lái)去除重復(fù)值。

`javascript

const arr = [1, 2, 3, 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]

方法五:使用forEach

我們可以使用forEach方法結(jié)合一個(gè)臨時(shí)的空數(shù)組來(lái)去除數(shù)組中的重復(fù)值。

`javascript

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

const uniqueArr = [];

arr.forEach(item => {

if (!uniqueArr.includes(item)) {

uniqueArr.push(item);

}

});

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

這些都是常用的去除數(shù)組中重復(fù)值的方法,你可以根據(jù)具體的需求選擇適合的方法來(lái)處理數(shù)組中的重復(fù)值。希望對(duì)你有所幫助!

千鋒教育擁有多年IT培訓(xùn)服務(wù)經(jīng)驗(yàn),開(kāi)設(shè)Java培訓(xùn)、web前端培訓(xùn)、大數(shù)據(jù)培訓(xùn),python培訓(xùn)軟件測(cè)試培訓(xùn)等課程,采用全程面授高品質(zhì)、高體驗(yàn)教學(xué)模式,擁有國(guó)內(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動(dòng)態(tài)路由有哪些?

一、常見(jiàn)的動(dòng)態(tài)路由協(xié)議以下是Linux中常見(jiàn)的動(dòng)態(tài)路由協(xié)議:1. RIP(Routing Information Protocol)RIP是一種距離向量路由協(xié)議,適用于小型網(wǎng)絡(luò)...詳情>>

2023-10-16 11:33:11
?如何在ThinkPHP6中使用路由?

一、基礎(chǔ)的路由定義 在ThinkPHP6中,路由是用于將URL地址映射到應(yīng)用的操作方法上。基礎(chǔ)的路由定義在route/app.php文件中,使用Route::rule方法...詳情>>

2023-10-16 11:25:24
如何生成Sitemap?

一、了解Sitemap的重要性Sitemap(站點(diǎn)地圖)為搜索引擎提供了網(wǎng)站上所有頁(yè)面的鏈接,它能有效地幫助搜索引擎蜘蛛更好地爬取和索引網(wǎng)站內(nèi)容。此...詳情>>

2023-10-16 10:59:00
如何進(jìn)行顏色選擇?

一、理解顏色的心理學(xué)意義在設(shè)計(jì)的每一步中,顏色都扮演著非常重要的角色。不同的顏色會(huì)引發(fā)不同的情感反應(yīng)和心理反應(yīng)。例如,紅色通常與激情、...詳情>>

2023-10-16 10:50:52
如何使用ThinkPHP6實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出?

一、環(huán)境和所需工具包的準(zhǔn)備在開(kāi)始實(shí)際的操作之前,確保您已經(jīng)安裝了ThinkPHP6框架并運(yùn)行正常。接著,我們需要一個(gè)PHP工具庫(kù)來(lái)方便處理Excel文...詳情>>

2023-10-16 10:29:28