最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

JavaScript數(shù)組去重的幾種方法

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 21:59:15
文檔

JavaScript數(shù)組去重的幾種方法

JavaScript數(shù)組去重的幾種方法:前言 有時(shí)候我們做項(xiàng)目的時(shí)候往往會(huì)需要把數(shù)組里面一些重復(fù)的項(xiàng)去掉,但是原生JS有排序,有篩選等等,但是就是沒(méi)有數(shù)組去重怎么辦呢? 這能怎么辦,自己手動(dòng)實(shí)現(xiàn)嘛。 數(shù)組不像對(duì)象和hash有唯一的標(biāo)志特征(key)。所以,數(shù)組去重的核心就是【1】數(shù)組內(nèi)元素互相
推薦度:
導(dǎo)讀JavaScript數(shù)組去重的幾種方法:前言 有時(shí)候我們做項(xiàng)目的時(shí)候往往會(huì)需要把數(shù)組里面一些重復(fù)的項(xiàng)去掉,但是原生JS有排序,有篩選等等,但是就是沒(méi)有數(shù)組去重怎么辦呢? 這能怎么辦,自己手動(dòng)實(shí)現(xiàn)嘛。 數(shù)組不像對(duì)象和hash有唯一的標(biāo)志特征(key)。所以,數(shù)組去重的核心就是【1】數(shù)組內(nèi)元素互相

前言

有時(shí)候我們做項(xiàng)目的時(shí)候往往會(huì)需要把數(shù)組里面一些重復(fù)的項(xiàng)去掉,但是原生JS有排序,有篩選等等,但是就是沒(méi)有數(shù)組去重怎么辦呢?

這能怎么辦,自己手動(dòng)實(shí)現(xiàn)嘛。

數(shù)組不像對(duì)象和hash有唯一的標(biāo)志特征(key)。所以,數(shù)組去重的核心就是【1】數(shù)組內(nèi)元素互相比較,然后放入新的數(shù)組中?!?】參照對(duì)象構(gòu)建一個(gè)唯一的特征標(biāo)志,然后放入新數(shù)組中。以下就是依照這種思路產(chǎn)生的方法。【3】數(shù)組中含對(duì)象的去重方式我采用使用JSON.stringify()將對(duì)象轉(zhuǎn)換成JSON字符串進(jìn)行比較的方式。

1.最基礎(chǔ)的去重:雙重遍歷

雙重遍歷的核心就是依據(jù)【1】,通過(guò)拿出一個(gè)元素和剩下的元素依次比較,如果全部不相等則證明此元素為唯一。

let a=[{a:1},{b:2},{c:3},{a:1},{d:2}]
let c=[1,2,3,4,5,6,1,2,3]
function unique(arr){
 let b=[]
 for(let i=0;i<arr.length;i++){
 let unexit=true
 for(let j=i+1;j<arr.length;j++){
 if(JSON.stringify(arr[i])===JSON.stringify(arr[j])){
 unexit=false
 break
 }
 else{
 unexit=true
 }
 }
 if(unexit){
 b.push(arr[i])
 }
 }
 return b
}

關(guān)于數(shù)組中存在對(duì)象,是采用JSON.stringify()轉(zhuǎn)換成JSON字符串進(jìn)行的比較,后續(xù)不再敘述。雙重遍歷的缺點(diǎn)是復(fù)雜度太高。
上面的代碼去重得到的結(jié)果的順序會(huì)改變,所以如果想要順序按照原有順序,數(shù)組在進(jìn)行去重時(shí)建議重新申明一個(gè)新的數(shù)組(var new=old.reverse() )得到一個(gè)新的相反的數(shù)組,最后再使用reverse()。之所以新建數(shù)組而不是直接取反是因?yàn)椋?code>reverse()會(huì)修改原數(shù)組。

2.Array.prototype.sort():相鄰元素去重

相鄰元素去重的核心在于Array.sort()能夠?qū)?shù)組進(jìn)行排序。這樣相等的數(shù)組就會(huì)在相鄰的位置,通過(guò)比較相鄰的元素就可以起到去重的作用【1】。

let c=[1,2,3,4,5,6,1,2,3]
function unique(arr){
 let Arr=arr.sort()
 let b=[]
 for(let i=0;i<Arr.length;i++){
 if(Arr[i]!==Arr[i+1]){
 b.push(Arr[i])
 }
 }
 return b
}

Array.prototype.sort()方法可以使用array.sort((a,b)=>{a.key-b.ky})進(jìn)行對(duì)象的排序,前提是數(shù)組中的對(duì)象存在相同的key值。

3.Object.keys():存在唯一性

在一個(gè)對(duì)象里面key值是唯一的,所以通過(guò)遍歷數(shù)組給每個(gè)數(shù)組一個(gè)標(biāo)志,通過(guò)標(biāo)志去重【2】

let a=[{a:1},{b:2},{c:3},{a:1},{d:2}]
let c=[1,2,3,4,5,6,1,2,3]
function unique(arr){
 let b=[]
 let hash={}
 for(let i=0;i<arr.length;i++){
 if(!hash[JSON.stringify(arr[i])]){
 hash[JSON.stringify(arr[i])]=true
 b.push(arr[i])
 }
 }
 return b
}

4.雙重遍歷去重改良之:indexOf

雙重遍歷的思路我們都知道,先拿出一個(gè)元素,然后使用循環(huán)再次遍歷數(shù)組去一一比較。如果有一個(gè)方式能夠讓我們不再遍歷一遍數(shù)組,那么復(fù)雜度相對(duì)而言會(huì)減少一點(diǎn)。

indexOf 方法返回給定元素在數(shù)組中第一次出現(xiàn)的位置,如果沒(méi)有出現(xiàn)則返回-1。首先我們新建一個(gè)空數(shù)組(arry),如果:arry.indexOf(數(shù)組元素)===-1,那么我們就可以知道arry中不存在元素。

let c=[1,2,3,4,5,6,1,2,3]
function unique(arr){
 let b=[]
 for(let i=0;i<arr.length;i++){
 if(b.indexOf(arr[i])==-1){
 b.push(arr[i])
 }
 }
 return b
}

indexOf 方法可返回某個(gè)指定的字符串值在字符串中首次出現(xiàn)的位置。所以對(duì)象不適用,因?yàn)閷?duì)象轉(zhuǎn)為字符串就都會(huì)變成{object,object} ,無(wú)法比較。

5.循環(huán)遍歷之:map()/forEach()

map()和forEach()都可以實(shí)現(xiàn)遍歷數(shù)組。所以以上的方法都可以用map()、forEach()改寫(xiě)。下面我只簡(jiǎn)單的改寫(xiě)一個(gè),其他的改寫(xiě)方式參照即可。

let c=[1,2,3,4,5,6,1,2,3]
function unique(arr){
 let b=[]
 arr.forEach(res=>{
 if(b.indexOf(res)==-1){
 b.push(res)
 }
 })
 return b
}

6.ES6:Set數(shù)據(jù)結(jié)構(gòu)

Set數(shù)據(jù)類似于數(shù)組,但是成員的值都是唯一的,沒(méi)有重復(fù)的值。它可以接收一個(gè)數(shù)組,類于:let a=[1,2,3,1,2]  Set(a)=>1,2,3 所以可以使用Set()實(shí)現(xiàn)去重。

let c=[1,2,3,4,5,6,1,2,3]
function unique(arr){
 let b=new Set(arr)
 let c=Array.from(b)
 return c
}

Set去重不適用于含對(duì)象的數(shù)組,因?yàn)镾et的去重參照的是(===),數(shù)組中的元素對(duì)象,雖然可能數(shù)值相等,但是地址不相等。所以Set無(wú)法實(shí)現(xiàn)去重。

7.總結(jié)

實(shí)現(xiàn)數(shù)組的去重,要么通過(guò)元素對(duì)比,要么設(shè)置特殊標(biāo)志識(shí)別。元素對(duì)比的思路有2種:一種是和原數(shù)組一一對(duì)比;另一種和新的數(shù)組對(duì)比。

如果要實(shí)現(xiàn)含對(duì)象的數(shù)組去重,一般使用遍歷的方式,包括使用遍歷類的方法(map、forEach、reduce等)。像Set、sort等通過(guò)改變數(shù)組的方式一般是不可行的。

好了,

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JavaScript數(shù)組去重的幾種方法

JavaScript數(shù)組去重的幾種方法:前言 有時(shí)候我們做項(xiàng)目的時(shí)候往往會(huì)需要把數(shù)組里面一些重復(fù)的項(xiàng)去掉,但是原生JS有排序,有篩選等等,但是就是沒(méi)有數(shù)組去重怎么辦呢? 這能怎么辦,自己手動(dòng)實(shí)現(xiàn)嘛。 數(shù)組不像對(duì)象和hash有唯一的標(biāo)志特征(key)。所以,數(shù)組去重的核心就是【1】數(shù)組內(nèi)元素互相
推薦度:
標(biāo)簽: 方法 種方法 js
  • 熱門(mén)焦點(diǎn)

最新推薦

猜你喜歡

熱門(mén)推薦

專題
Top