js數(shù)組去重

1.es6中的set去重

語法new Set(要去重的數(shù)組)我纪,返回一個數(shù)組

eg:

var arr1= [1,3,4,1,4,5,7,{},{},NaN,true,null,true,‘hahah’,‘kk’,‘hahah’,NaN,null]

var arr2 = new Set(arr1);

console.log(arr1);

console.log(arr2);

// 語法new Set(要去重的數(shù)組),返回一個數(shù)組

注:此方法有一個缺陷不能去掉多余的對象

2泼舱,slice去重

var arr1 = [1,1,3,4,2,4,3,2,5,7,3]

for(var i=0;i<arr1.length;i++){

for(var j=i+1;j<arr1.length;j++){

if(arr1[j]==arr1[i]){

arr1.splice(j,1)

}

}

}

console.log(arr1);

3.indexOf去重

該方法重新申明了一個數(shù)組array蹲盘,for循環(huán)原數(shù)組祭陷,每次循環(huán)時判斷array中是否包含該次循環(huán)的元素苍凛,如果不包含就將這個元素添加到array中去。

function unique(arr) {

var array = [];

for(var i=0;i<arr.length;i++){

if(array.indexOf(arr[i])==-1){

array.push(arr[i])

}

}

return array;

}

var arr= [1,1,3,4,2,4,3,2,5,7,3]

console.log(unique(arr));

4.sort

先調(diào)用sort方法排好序悠栓,在依次比較相鄰兩個元素是否相同,不同就push到新數(shù)組里面去

function unique(arr) {

arr = arr.sort()

var array = [arr[0]];

for(var i=1;i<arr.length;i++){

if(arr[i]!==array[i-1]){

array.push(arr[i])

}

}

return array;

}

var arr = [1,1,3,4,2,4,3,2,5,7,3]

console.log(arr.length);

console.log(unique(arr));

5.利用對象的屬性不能重復去重

function unique(arr) {

var obj = {};

var array = [];

for(var i=0;i<arr.length;i++){

if(!obj[arr[i]]){

array.push(arr[i])

obj[arr[i]] = 1;

console.log(‘1’,obj);

}else{

obj[arr[i]]++

console.log(‘2’,obj);

}

}

return array;

}

var arr= [1,1,3,4,2,4,3,2,5,7,3]

console.log(unique(arr));

6.includes去重

includes方法和indexof方法用法差不多今阳,但是indexOf有一個缺點蘸鲸,無法判斷數(shù)組中的NaN技潘。

聲明一個數(shù)組,循環(huán)原數(shù)組携栋,當這個數(shù)組里面里面不包含原數(shù)組里面的數(shù)據(jù)時,將當前循環(huán)到的數(shù)據(jù)蛀蜜,push到聲明的數(shù)組里去刻两。

function unique(arr) {

var array = [];

for(var i=0;i<arr.length;i++){

if(!array.includes(arr[i])){

array.push(arr[i])

}

}

return array;

}

var arr= [1,1,3,4,2,4,3,2,5,7,3]

console.log(unique(arr));

7.利用hasOwnProperty 判斷是否存在對象屬性與filter結(jié)合

function unique(arr) {

var obj = {};

return arr.filter(function (item) {

console.log(typeof item + item);

return obj.hasOwnProperty(typeof item+item)?false:(obj[typeof item+item]=true)

})

}

var arr= [1,1,3,4,2,4,3,2,5,7,3]

console.log(unique(arr));

8.利用filter

function unique(arr) {

return arr.filter(function (item,index) {

console.log(arr.indexOf(item,0));

//找到item增蹭,返回當前下標

return arr.indexOf(item,0) === index

})

}

var arr= [1,1,3,4,2,4,3,2,5,7,3]

console.log(unique(arr));

————————————————

版權(quán)聲明:本文為CSDN博主「YOYOyxl」的原創(chuàng)文章滴某,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請附上原文出處鏈接及本聲明滋迈。

原文鏈接:https://blog.csdn.net/YOYOyxl/article/details/106990271

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末霎奢,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子饼灿,更是在濱河造成了極大的恐慌幕侠,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件碍彭,死亡現(xiàn)場離奇詭異晤硕,居然都是意外死亡,警方通過查閱死者的電腦和手機庇忌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進店門舞箍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人皆疹,你說我怎么就攤上這事疏橄。” “怎么了略就?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵捎迫,是天一觀的道長。 經(jīng)常有香客問我表牢,道長窄绒,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任崔兴,我火速辦了婚禮彰导,結(jié)果婚禮上浊闪,老公的妹妹穿的比我還像新娘。我一直安慰自己螺戳,他們只是感情好搁宾,可當我...
    茶點故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著倔幼,像睡著了一般盖腿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上损同,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天翩腐,我揣著相機與錄音,去河邊找鬼膏燃。 笑死茂卦,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的组哩。 我是一名探鬼主播等龙,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼伶贰!你這毒婦竟也來了蛛砰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤黍衙,失蹤者是張志新(化名)和其女友劉穎泥畅,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體琅翻,經(jīng)...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡位仁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了方椎。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片聂抢。...
    茶點故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖辩尊,靈堂內(nèi)的尸體忽然破棺而出涛浙,到底是詐尸還是另有隱情,我是刑警寧澤摄欲,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布轿亮,位于F島的核電站,受9級特大地震影響胸墙,放射性物質(zhì)發(fā)生泄漏我注。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一迟隅、第九天 我趴在偏房一處隱蔽的房頂上張望但骨。 院中可真熱鬧励七,春花似錦、人聲如沸奔缠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽校哎。三九已至两波,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間闷哆,已是汗流浹背腰奋。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留抱怔,地道東北人劣坊。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像屈留,于是被迫代替她去往敵國和親局冰。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,435評論 2 359