JS實(shí)現(xiàn)數(shù)組去重及數(shù)組內(nèi)對(duì)象去重功能示例
本文實(shí)例講述了JS實(shí)現(xiàn)數(shù)組去重及數(shù)組內(nèi)對(duì)象去重功能。分享給大家供大家參考,具體如下:
大家在寫項(xiàng)目的時(shí)候一定遇到過這種邏輯需求,就是給一個(gè)數(shù)組進(jìn)行去重處理,還有一種就是給數(shù)組內(nèi)的對(duì)象根據(jù)某一個(gè)屬性,比如id,進(jìn)行去重,下面我寫了兩個(gè)函數(shù),都是可以達(dá)到這個(gè)效果的,一個(gè)是純ES5的去重辦法,一個(gè)是用了ES6的 Array.from(new Set())和ES5的reduce來進(jìn)行去重
我先定義兩個(gè)數(shù)組吧
var arr = [1,2,3,5,3,4,5,6,6,"test","test",true];
var person = [
{
name:"孫悟空",
weapon:"如意金箍棒",
experience:"大鬧天宮、西天取經(jīng)",
post:"斗戰(zhàn)勝佛、齊天大圣"
},
{
name:"孫悟空",
weapon:"如意金箍棒",
experience:"大鬧天宮、西天取經(jīng)",
post:"斗戰(zhàn)勝佛、齊天大圣"
},
{
name:"孫悟空",
weapon:"如意金箍棒",
experience:"大鬧天宮、西天取經(jīng)",
post:"斗戰(zhàn)勝佛、齊天大圣"
},
{
name:"孫悟空",
weapon:"如意金箍棒",
experience:"大鬧天宮、西天取經(jīng)",
post:"斗戰(zhàn)勝佛、齊天大圣"
},
{
name:"孫悟空",
weapon:"如意金箍棒",
experience:"大鬧天宮、西天取經(jīng)",
post:"斗戰(zhàn)勝佛、齊天大圣"
}
];
ES5版本:
//ES5原生去重辦法
function Es5duplicate(arr,type){
var newArr = [];
var tArr = [];
if(arr.length == 0){
return arr;
}else{
if(type){
for(var i = 0; i < arr.length;i++){
if(!tArr[arr[i][type]]){
newArr.push(arr[i]);
tArr[arr[i][type]] = true;
}
}
return newArr;
}else{
for(var i = 0; i < arr.length;i++){
if(!tArr[arr[i]]){
newArr.push(arr[i]);
tArr[arr[i]] = true;
}
}
return newArr;
}
}
}
console.log('ES5去重',Es5duplicate(arr));
console.log('ES5去重',Es5duplicate(person,"name"));
ES6 + ES5版本:
//Es6 + ES5去重辦法
function Es6duplicate(arr,type){
if(arr.length == 0){
return arr;
}else{
if(type){
var obj = {}
var newArr = arr.reduce((cur,next) => {
obj[next.name] ? "" : obj[next.name] = true && cur.push(next);
return cur;
},[])
return newArr;
}else{
return Array.from(new Set(arr));
}
}
}
console.log('ES6去重',Es6duplicate(arr));
console.log('ES6去重',Es6duplicate(person,"name"));
看下結(jié)果

看起來好像是第二種辦法代碼量要小一些,但是第一個(gè)通用,兼容性特別好,第二個(gè)因?yàn)闋砍兜搅薊S6新特性,所以還是要考慮一下兼容性,但是如果你要是在vue-cli初始化生成的項(xiàng)目,可以隨便用ES6的新特性,他自動(dòng)轉(zhuǎn)譯了,我自己搭建了一個(gè)demo,試了好多新特性,IE9+都有效果(本身vue就不支持IE8及以下,所以IE9以下沒辦法實(shí)驗(yàn))
PS:這里再為大家提供幾款相關(guān)工具供大家參考使用:
在線去除重復(fù)項(xiàng)工具:
http://tools.jb51.net/code/quchong
在線文本去重復(fù)工具:
http://tools.jb51.net/aideddesign/txt_quchong
更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專題:《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript字符與字符串操作技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
詳解js私有作用域中創(chuàng)建特權(quán)方法
這篇文章主要為大家詳細(xì)介紹了js私有作用域中創(chuàng)建特權(quán)方法,何為特權(quán)方法,特權(quán)方法就是有權(quán)訪問私有變量和私有函數(shù)的公有方法,感興趣的小伙伴們可以參考一下2016-01-01
D3.js 實(shí)現(xiàn)帶伸縮時(shí)間軸拓?fù)鋱D的示例代碼
這篇文章主要介紹了D3.js 實(shí)現(xiàn)帶伸縮時(shí)間軸拓?fù)鋱D的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
js實(shí)現(xiàn)文件流式下載文件方法詳解及完整代碼
這篇文章主要介紹了用js實(shí)現(xiàn)讀取文件流并下載到本地的方法,也就是我們經(jīng)常說的使用js下載文件需要的朋友可以參考下2022-12-12
javascript寫一個(gè)ajax自動(dòng)攔截并下載數(shù)據(jù)代碼實(shí)例
這篇文章主要介紹了javascript寫一個(gè)ajax自動(dòng)攔截并下載數(shù)據(jù)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
javaScript 判斷字符串是否為數(shù)字的簡(jiǎn)單方法
javascript在通過parseIn或parseFloat將字符串轉(zhuǎn)化為數(shù)字的過程中,如果字符串中包含有非數(shù)字,那么將會(huì)返回NaN,參考下面代碼2009-07-07

