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: "哈哈"}]
  • 相关阅读:
    unity代码加密for Android,mono编译
    php __invoke 和 __autoload
    VC只运行一个程序实例
    VC单文档对话框添加托盘图标
    技术文档应该怎么写
    项目管理学习
    cannot download, /home/azhukov/go is a GOROOT, not a GOPATH
    Go语言学习
    appium键盘事件
    appium-doctor
  • 原文地址:https://www.cnblogs.com/wswm/p/13685602.html
Copyright © 2011-2022 走看看