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

    // 数组去重
    {
       const arr = [1,2,3,4,1,23,5,2,3,5,6,7,8,undefined,null,null,undefined,true,false,true,‘中文‘,‘‘,‘‘,‘hello‘,‘中文‘];
       //  第一种
       const r = [...new Set(arr)];
       console.log(r); // [1, 2, 3, 4, 23, 5, 6, 7, 8, undefined, null, true, false, "中文", "", "hello"]
    
       
       // 第二种
       const R = arr.reduce((all,name) => all.includes(name) ? all :[...all,name],[]);
       console.log(R); // [1, 2, 3, 4, 23, 5, 6, 7, 8, undefined, null, true, false, "中文", "", "hello"]
       
       // 第三种
       const k = arr.filter((item, i) => i === arr.indexOf(item));
       console.log(k); // [1, 2, 3, 4, 23, 5, 6, 7, 8, undefined, null, true, false, "中文", "", "hello"]
    }
    
    
    // 统计每个元素在数组中出现的次数
    {
       const arr = [‘zhangsan‘, ‘lisi‘, ‘wangwu‘, ‘zhangsan‘, ‘lisi‘, ‘wangwu‘,‘zhaosi‘,‘liuneng‘];
       const r = arr.reduce((all, name) =>{
          if(name in all){
             all[name]++
          }else{
             all[name] = 1;
          }
          return all;
       },{});
       console.log(r); // {zhangsan: 2, lisi: 2, wangwu: 2, zhaosi: 1, liuneng: 1}
    }
    
    // 数组对象去重
    {
       const arr = [
          {
             name:‘zhangsan‘,
                age:12
          },
            {
             name:‘lisi‘,
             age:14
          },
          {
             name:‘zhangsan‘,
                age:12
          },
            {
             name:‘lisi‘,
             age:14
          },
          {
             name:‘zhangsan‘,
                age:12
          },
            {
             name:‘lisi‘,
             age:14
          },
          {
             name:‘zhangsan‘,
                age:12
          },
            {
             name:‘wangwu‘,
             age:16
          },
          {
             name:‘wagnwu‘,
                age:16
          },
            {
             name:‘lisi‘,
             age:14
          },
          
       ]
       
       // 根据 age 去重
        // 方法一
        const age = ‘age‘;
       const r = arr.reduce((all, next) => all.some((atom) => atom[age] == next[age]) ? all : [...all, next],[]);
       console.log(r);
    
    }
    

      

  • 相关阅读:
    原生JS中apply()方法的一个值得注意的用法
    关于“float”的一次探索--遇到了一个span元素可以设置宽高引发的思考
    git常用命令
    react 项目全家桶构件流程
    vue回顶部 组件 可以直接使用
    vscode左边侧边栏字体的大小
    小程序的福音,
    Android实战技巧:Dialog (转)
    给Android 应用开发者的十个建议(转)
    多线程与异步的区别(转)
  • 原文地址:https://www.cnblogs.com/lilelile/p/11350962.html
Copyright © 2011-2022 走看看