js中數組對象去重的方法


 

方法一:

采用對象訪問屬性的方法,判斷屬性值是否存在,如果不存在就添加。

方法二:

采用數組中的reduce方法,遍歷數組,也是通過對象訪問屬性的方法

復制代碼
 1  var arr = [{
 2       key: '01',
 3       value: '樂樂'
 4    }, {
 5       key: '02',
 6       value: '博博'
 7    }, {
 8       key: '03',
 9       value: '淘淘'
10    },{
11       key: '04',
12       value: '哈哈'
13    },{
14       key: '01',
15       value: '樂樂'
16    }];
17 
18 
19    //  方法1:利用對象訪問屬性的方法,判斷對象中是否存在key
20    var result = [];
21    var obj = {};
22    for(var i =0; i<arr.length; i++){
23       if(!obj[arr[i].key]){
24          result.push(arr[i]);
25          obj[arr[i].key] = true;
26       }
27    }
28    console.log(result); // [{key: "01", value: "樂樂"},{key: "02", value: "博博"},{key: "03", value: "淘淘"},{key: "04", value: "哈哈"}]
29 
30 
31 
32    //  方法2:利用reduce方法遍歷數組,reduce第一個參數是遍歷需要執行的函數,第二個參數是item的初始值
33       var obj = {};
34     arr = arr.reduce(function(item, next) {
35       obj[next.key] ? '' : obj[next.key] = true && item.push(next);
36       return item;
37    }, []);
38    console.log(arr); // [{key: "01", value: "樂樂"},{key: "02", value: "博博"},{key: "03", value: "淘淘"},{key: "04", value: "哈哈"}]


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM