zoukankan      html  css  js  c++  java
  • js中数组对象去重的方法

    最近工作中需要用到数组对象去重的方法,我是怎么想也没想出来,今天稍微研究了一下,总算找到了2种方法。分享一下,希望对大家有帮助!

    方法一:

    采用对象访问属性的方法,判断属性值是否存在,如果不存在就添加。

    方法二:

    采用数组中的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: "哈哈"}]
    复制代码
  • 相关阅读:
    js函数的Json写法
    Bootstrap3和Bootstrap4区别
    Unicode编码是什么
    保留字是什么
    范仁义js课程---5、js字面量和变量
    什么是脚本语言
    ECMAScript 版本
    TortoiseGit上传代码到GitHub
    Android Studio快捷键
    Android 适配
  • 原文地址:https://www.cnblogs.com/BluceLee/p/13524506.html
Copyright © 2011-2022 走看看