javascript - js判斷一個(gè)數(shù)組是否重復(fù)
問題描述
js怎么判斷一個(gè)數(shù)組對(duì)象里面有重復(fù)的值,并且刪除重復(fù)的值只保留一個(gè)比如 var arr = [{name:’a’},{name:’b’},{name:’c’},{name:’d’},{name:’a’}] 怎么對(duì)比
問題解答
回答1:可以雙for循環(huán)去找,用第一個(gè)和后面挨個(gè)對(duì)比,重復(fù)則刪除,在從第二個(gè)找,在向后對(duì)比,重復(fù)則刪除
const del = (arr) => { for( let i=0;i<arr.length;i++) {for(let j=i+1;j<arr.length;j++) { if (arr[i].id==arr[j].id) {arr.splice(j,1);i--; }} } return arr;}回答2:
突發(fā)奇想寫的。。。不知道是否滿足所有要求。。。哈哈
方法一:
const del = (arr)=>{ let map = []; for(let i = 0; i < arr.length; i++) { let key = JSON.stringify(arr[i]); if(map.includes(key)) {arr.splice(i, 1);i--; } else {map.push(key); } } return arr;}
方法二:
const del = arr=>Array.from(new Set(arr.map(a=>JSON.stringify(a)))).map(a=>JSON.parse(a))回答3:
temp.indexOf ( arr[i].name ) = -1;
res.push(arr[i]);
數(shù)組去重方法比較多,你還可以有更好的方法
回答4:原材料arr 是一維數(shù)組 而且元素是對(duì)象。 要處理的內(nèi)容是該對(duì)象下的 name 屬性。
var arr = [{name:’a’},{name:’b’},{name:’c’},{name:’d’},{name:’a’}]處理思路
遍歷他,然后在每次遍歷的 item 基礎(chǔ)上再遍歷一次 arr 挨個(gè)對(duì)比 如果發(fā)現(xiàn)重復(fù)就留個(gè)記錄
var logger = (a, b) => { console.group(’誰重復(fù)了?’); console.log(’元素:’, a); console.log(’下標(biāo):’, b); console.groupEnd(); }// 遍歷 arr.filter((item, idx, its) => { // 一旦發(fā)現(xiàn)有重復(fù)的元素就返回 true (通過 its.some 注意他的兩個(gè)參數(shù) e 和 idx2) // 無重復(fù)的過濾掉 return its.some((e, idx2) => {return (e.name === item.name && idx2 !== idx); });}).forEach(logger); ScreenShot
// 數(shù)組去重// 有key表示是復(fù)雜數(shù)組去重,根據(jù)數(shù)組中對(duì)象的屬性key來去重function arrUniq(arr, key) {
if (!Array.isArray(arr) || arr.length < 2) { return arr;}// 簡(jiǎn)單數(shù)組去重if (!key) { return Array.from(new Set(arr));}// 復(fù)雜數(shù)組去重var obj = {}, res = [];arr.forEach((item) => { if (!obj[item[key]]) {res.push(item);obj[item[key]] = true; }});return res;
}
相關(guān)文章:
1. angular.js - angular內(nèi)容過長(zhǎng)展開收起效果2. docker網(wǎng)絡(luò)端口映射,沒有方便點(diǎn)的操作方法么?3. docker - 各位電腦上有多少個(gè)容器啊?容器一多,自己都搞混了,咋辦呢?4. docker綁定了nginx端口 外部訪問不到5. nignx - docker內(nèi)nginx 80端口被占用6. fragment - android webView 返回后怎么禁止重新渲染?7. docker不顯示端口映射呢?8. php - mysql 模糊搜索問題9. java - 為什么此私有靜態(tài)變量能被訪問呢?10. php - 第三方支付平臺(tái)在很短時(shí)間內(nèi)多次異步通知,訂單多次確認(rèn)收款
