簡體   English   中英

如何獲取 JavaScript 中所有數組項中存在的公共值元素

[英]How to get elements of common value present in all items of Array in JavaScript

var  rowsList = [
                    {
                        otherAttribute: "4fwdw-3wxs-4b60-a46b-175a07f7f53e",
                        subrows:[
                                {subDataRowId: "abc", amount: 4000},
                                {subDataRowId: "lmn", amount: 200},
                                {subDataRowId: "76d88372", amount: 9999}
                              ]
                    },              
                    {
                        otherAttribute: "373d2-1bfb-4b60-a46b-175a07f7f53e",
                        subrows:[
                                {subDataRowId: "abc", amount: 4000},
                                {subDataRowId: "4dss", amount: 300},
                                {subDataRowId: "vxy", amount: 200},
                                {subDataRowId: "lmn", amount: 9999}
                              ]
                    },
                    {
                        otherAttribute: "99ssd-1bfb-4b60-a46b-175a07f7f53e",
                        subrows:[
                                {subDataRowId: "abc", amount: 4000},
                                {subDataRowId: "vxy", amount: 800},
                                {subDataRowId: "mdn", amount: 300},
                                {subDataRowId: "lmn", amount: 200}
                              ]
                    }
                ];

如何根據在所有子行中具有公共subDataRowId來獲取過濾列表。 預計 output 尋找如下 -

rowWiseSubrowFoundArray = [
                            [
                              {subDataRowId: "abc", amount: 4000},
                              {subDataRowId: "lmn", amount: 200}
                            ],              
                            [
                              {subDataRowId: "abc", amount: 4000},
                              {subDataRowId: "lmn", amount: 9999}
                            ],
                             [
                               {subDataRowId: "abc", amount: 4000},
                               {subDataRowId: "lmn", amount: 200}
                            ]
                    ];

我試圖找到所有數組項中都存在的常見項。 我嘗試像下面那樣獲取重復項並使用“rowList”子行對其進行迭代。 但沒有得到預期的 output。

//
findDuplicateItemsInArray = (array) => {
    let arrayItem = {};
    let duplicateItems = [];
    array.forEach(function (itemIndex) {
        if (!arrayItem[itemIndex])
            arrayItem[itemIndex] = 0;
        arrayItem[itemIndex] += 1;
    })

    for (var prop in arrayItem) {
        if (arrayItem[prop] >= 2) {
            duplicateItems.push(prop);
        }
    }
    return duplicateItems;
}

// get all subrows
let subrows = [];           
rowsList.forEach((row) => {
    row.subrows.forEach((subrow)=> {
        subrows.push(subrow);
    });
});

//get unique subrows 
const uniqueSubrowsArray = findDuplicateItemsInArray(subrows.map((subrow) => subrow.subDataRowId));

console.log(uniqueSubrowsArray);

let rowWiseSubrowFoundArray = [];

rowsList.forEach((row) => { 
      let subrowFound = [];
      
    
      row.subrows.forEach((subrow) =>{
            uniqueSubrowsArray.forEach((uniqueSubrow)=>{
                    if(uniqueSubrow == subrow.subDataRowId){
            subrowFound.push(subrow);
                    }
            })                  
      });
      
    rowWiseSubrowFoundArray.push(subrowFound);      
});

console.log('rowWiseSubrowFoundArray', rowWiseSubrowFoundArray);

小提琴鏈接 -

https://jsfiddle.net/guruling/e64atjds/74/

這回答了你的問題了嗎?

 var rowsList = [ { otherAttribute: "4fwdw-3wxs-4b60-a46b-175a07f7f53e", subrows:[ {subDataRowId: "abc", amount: 4000}, {subDataRowId: "lmn", amount: 200}, {subDataRowId: "76d88372", amount: 9999} ] }, { otherAttribute: "373d2-1bfb-4b60-a46b-175a07f7f53e", subrows:[ {subDataRowId: "abc", amount: 4000}, {subDataRowId: "4dss", amount: 300}, {subDataRowId: "vxy", amount: 200}, {subDataRowId: "lmn", amount: 9999} ] }, { otherAttribute: "99ssd-1bfb-4b60-a46b-175a07f7f53e", subrows:[ {subDataRowId: "abc", amount: 4000}, {subDataRowId: "vxy", amount: 800}, {subDataRowId: "mdn", amount: 300}, {subDataRowId: "lmn", amount: 200} ] } ]; const filterInput = (inputIds) => rowsList.map(val => val.subrows.filter(row => inputIds.indexOf(row.subDataRowId);== -1)), const filteredData = filterInput(["abc"; "lmn"]). //Pass the input Ids for filtering console;log(filteredData);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM