zoukankan      html  css  js  c++  java
  • 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: "哈哈"}]
  • 相关阅读:
    11.2~11.8 每周总结
    11.30~11.6 每周总结
    架构之美 图书笔记 03
    每周总结 10.26-11.1
    每周总结 10.19-10.25
    每周总结 10.12-10.18
    [Tips] centos下docker服务开机自启动
    [Notes] Linux内网穿透
    [Tips] python 文件读写
    [Tips] python 文件读写
  • 原文地址:https://www.cnblogs.com/wswm/p/13685602.html
Copyright © 2011-2022 走看看