zoukankan      html  css  js  c++  java
  • 对象数组,对比多个数组的相同子元素并筛选

    项目情景

    多选框,回显用户已选的选项。此时有两个数组,list1为多选选项列表,list2为用户已选择的选项

    第一个数组    list1 = [{name:'aa'}, {name:'bb'}, {name:'cc'}];

    第二个数组     list2= ['aa', 'bb'];

    目的:筛选已选选项保存,格式: [{"name":"aa","isSame":"Y"},{"name":"bb","isSame":"Y"},{"name":"cc","isSame":"N"}]

    错误做法

    通过遍历两个数组,筛选重复元素push到same数组中;

     1 <script>
     2     let list1 = [{name:'aa'}, {name:'bb'}, {name:'cc'}];
     3     let list2 = ['aa', 'bb'];
     4     let same = [];
     5     for (let i = 0; i < list1.length; i++) {
     6         list1[i].isCheck = 'isFalse';
     7         for (let j = 0; j < list2.length; j++) {
     8             if (list1[i].name == list2[j]) {
     9                same.push({
    10                    name:list1[i].name,
    11                    isSame:'Y'
    12                });
    13             }else{
    14                 same.push({
    15                     name:list1[i].name,
    16                     isSame:'N'
    17                 });
    18             }
    19         }
    20     }
    21     console.log('same',same);
    22 </script>
    View Code

    此时输出结果如下图: 

    我们会发现same中被push了6个元素,但是正确结果应该是2个元素。

    原因是双层for循环共执行了6次,每次都进行比对、push,所以push了6个元素。

    正确办法

    为筛选出的相同元素添加一个属性,避免重复向same数组push。

    <script>
        let list1 = [{name:'aa'}, {name:'bb'}, {name:'cc'}];
        let list2 = ['aa', 'bb'];
        let same = [];
        for (let i = 0; i < list1.length; i++) {
            list1[i].isCheck = 'isFalse';
            for (let j = 0; j < list2.length; j++) {
                if (list1[i].name == list2[j]) {
                    list1[i].isCheck = 'isTrue';
                }
            }
        }
        for (let i = 0; i < list1.length; i++) {
            same.push({
                name: list1[i].name,
                isSame: list1[i].isCheck == 'isTrue' ? 'Y' : 'N'
            })
        }
        console.log('same',JSON.stringify(same));
    </script>

    此时输出结果为:

    same [{"name":"aa","isSame":"Y"},{"name":"bb","isSame":"Y"},{"name":"cc","isSame":"N"}]
  • 相关阅读:
    Spring Cloud入门
    HTML常用标签
    Spring boot 入门
    数据库 基本操作
    jquery中的ajax方法参数
    反射详解
    SpringMVC框架
    Java NIO
    MQ(消息队列)的使用场景以及常见的MQ
    英文字母和中文汉字在不同字符集编码下的字节数
  • 原文地址:https://www.cnblogs.com/lemoncool/p/8571743.html
Copyright © 2011-2022 走看看