javascript - js判斷一個數(shù)組是否重復
問題描述
js怎么判斷一個數(shù)組對象里面有重復的值,并且刪除重復的值只保留一個比如 var arr = [{name:’a’},{name:’b’},{name:’c’},{name:’d’},{name:’a’}] 怎么對比
問題解答
回答1:可以雙for循環(huán)去找,用第一個和后面挨個對比,重復則刪除,在從第二個找,在向后對比,重復則刪除
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ù)組 而且元素是對象。 要處理的內(nèi)容是該對象下的 name 屬性。
var arr = [{name:’a’},{name:’b’},{name:’c’},{name:’d’},{name:’a’}]處理思路
遍歷他,然后在每次遍歷的 item 基礎上再遍歷一次 arr 挨個對比 如果發(fā)現(xiàn)重復就留個記錄
var logger = (a, b) => { console.group(’誰重復了?’); console.log(’元素:’, a); console.log(’下標:’, b); console.groupEnd(); }// 遍歷 arr.filter((item, idx, its) => { // 一旦發(fā)現(xiàn)有重復的元素就返回 true (通過 its.some 注意他的兩個參數(shù) e 和 idx2) // 無重復的過濾掉 return its.some((e, idx2) => {return (e.name === item.name && idx2 !== idx); });}).forEach(logger); ScreenShot
// 數(shù)組去重// 有key表示是復雜數(shù)組去重,根據(jù)數(shù)組中對象的屬性key來去重function arrUniq(arr, key) {
if (!Array.isArray(arr) || arr.length < 2) { return arr;}// 簡單數(shù)組去重if (!key) { return Array.from(new Set(arr));}// 復雜數(shù)組去重var obj = {}, res = [];arr.forEach((item) => { if (!obj[item[key]]) {res.push(item);obj[item[key]] = true; }});return res;
}
相關文章:
1. python - scrapy url去重2. Python從URL中提取域名3. node.js - 微信小程序websocket連接問題4. python執(zhí)行cmd命令,怎么讓他執(zhí)行類似Ctrl+C效果將其結束命令?5. 實現(xiàn)bing搜索工具urlAPI提交6. Python中使用超長的List導致內(nèi)存占用過大7. python - Django有哪些成功項目?8. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)9. 數(shù)據(jù)庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。10. 鏈接圖片時,鏈接不成功
