簡體   English   中英

如何過濾嵌套數組對象?

[英]How to Filter Nested Array Object?

所以我試圖從2個數組對象中排序數據,

我嘗試使用Loadash在兩者之間匹配相同的ID,但是我想要的結果仍然為空

Array A

    {
      "account": {
        "_id": "5d1efe79dedfe54a984f27f7",
        "status": "not verified",
        "email": "garp@garp.com",
        "name": "garp",
        "phone": "12345",
        "business_id": [
          {
            "role_capability": "all_access",
            "current_active": true,
            "_id": "5d1efe89dedfe54a984f27f9",
            "date_created": "1562309081438",
            "name": "balsem",
            "status": "no verify",
            "desc": "perusahaan balsem untuk nyeri otot"
          },
          {
            "role_capability": "all_access",
            "current_active": false,
            "_id": "5d1efe9adedfe54a984f27fb",
            "date_created": "1562309081438",
            "name": "pulpen",
            "status": "no verify",
            "desc": "pulpen adalah alat untuk nulis"
          },
          {
            "role_capability": "all_access",
            "current_active": false,
            "_id": "5d1efeacdedfe54a984f27fd",
            "date_created": "1562309081438",
            "name": "kaca mobil",
            "status": "no verify",
            "desc": "perusahaan yang bergerak di bidang kaca mobil"
          }
        ]
      }
    }

陣列B

    [
      {
        "_id": "5d1eebb0e3864b452044590a",
        "address": "",
        "status": "no verify",
        "email": "qwe@qwe.com",
        "name": "qwe",
        "phone": "2123123",
        "business_id": [
          {
            "_id": "5d1eebbde3864b452044590c",
            "role_capability": "all_access"
          },
          {
            "_id": "5d1ef967dedfe54a984f27ee",
            "role_capability": "all_access"
          }
        ]
      },
      {
        "_id": "5d1efe20dedfe54a984f27f1",
        "address": "",
        "status": "not verified",
        "email": "bart@bart.com",
        "name": "Bartolomew",
        "phone": "12344",
        "business_id": [
          {
            "_id": "5d1efe4fdedfe54a984f27f3",
            "role_capability": "all_access"
          },
          {
            "_id": "5d1efe5ddedfe54a984f27f5",
            "role_capability": "all_access"
          }
        ]
      },
      {
        "_id": "5d1efe79dedfe54a984f27f7",
        "address": "",
        "status": "not verified",
        "email": "garp@garp.com",
        "name": "garp",
        "phone": "12345",
        "business_id": [
          {
            "_id": "5d1efe89dedfe54a984f27f9",
            "role_capability": "all_access"
          },
          {
            "_id": "5d1efe9adedfe54a984f27fb",
            "role_capability": "all_access"
          },
          {
            "_id": "5d1efeacdedfe54a984f27fd",
            "role_capability": "all_access"
          }
        ]
      },
      {
        "_id": "5d1efecededfe54a984f27ff",
        "address": "",
        "status": "not verified",
        "email": "kizaru@kizaru.com",
        "name": "kizaru",
        "phone": "12345",
        "business_id": [
          {
            "_id": "5d1efedededfe54a984f2801",
            "role_capability": "all_access"
          },
          {
            "_id": "5d1efef6dedfe54a984f2803",
            "role_capability": "all_access"
          }
        ]
      }
    ]

這是我的用法

    let respFilter
    //first I sort the current_active data which is true
    const busActive = _.filter(cookieActive, function(o) {return  o.current_active === true; });

    //Response data from axios / Array B
    _.forEach(response.data, data => {
    // Then i looping Array B to get an _id and filter with Array A
    respFilter = _.filter(data, response.data[data] === busActive[0]._id)
    })
    //But i still get empty data
    console.log('respoFIlt', respFilter)

result that i want:

    {
        "_id": "5d1efe79dedfe54a984f27f7",
        "address": "",
        "status": "not verified",
        "email": "garp@garp.com",
        "name": "garp",
        "phone": "12345",
        "business_id": [
          {
            "_id": "5d1efe89dedfe54a984f27f9",
            "role_capability": "all_access"
          },
          {
            "_id": "5d1efe9adedfe54a984f27fb",
            "role_capability": "all_access"
          },
          {
            "_id": "5d1efeacdedfe54a984f27fd",
            "role_capability": "all_access"
          }
        ]
      },

我如何證明這一點? 我上面的步驟有什么問題。 抱歉,如果有一個錯誤的單詞,我為此使用了谷歌翻譯

先感謝您

只需在第二個數組中find具有正確_id的項目即可:

 const obj = {"account":{"_id":"5d1efe79dedfe54a984f27f7","status":"not verified","email":"garp@garp.com","name":"garp","phone":"12345","business_id":[{"role_capability":"all_access","current_active":true,"_id":"5d1efe89dedfe54a984f27f9","date_created":"1562309081438","name":"balsem","status":"no verify","desc":"perusahaan balsem untuk nyeri otot"},{"role_capability":"all_access","current_active":false,"_id":"5d1efe9adedfe54a984f27fb","date_created":"1562309081438","name":"pulpen","status":"no verify","desc":"pulpen adalah alat untuk nulis"},{"role_capability":"all_access","current_active":false,"_id":"5d1efeacdedfe54a984f27fd","date_created":"1562309081438","name":"kaca mobil","status":"no verify","desc":"perusahaan yang bergerak di bidang kaca mobil"}]}}; const arr = [{"_id":"5d1eebb0e3864b452044590a","address":"","status":"no verify","email":"qwe@qwe.com","name":"qwe","phone":"2123123","business_id":[{"_id":"5d1eebbde3864b452044590c","role_capability":"all_access"},{"_id":"5d1ef967dedfe54a984f27ee","role_capability":"all_access"}]},{"_id":"5d1efe20dedfe54a984f27f1","address":"","status":"not verified","email":"bart@bart.com","name":"Bartolomew","phone":"12344","business_id":[{"_id":"5d1efe4fdedfe54a984f27f3","role_capability":"all_access"},{"_id":"5d1efe5ddedfe54a984f27f5","role_capability":"all_access"}]},{"_id":"5d1efe79dedfe54a984f27f7","address":"","status":"not verified","email":"garp@garp.com","name":"garp","phone":"12345","business_id":[{"_id":"5d1efe89dedfe54a984f27f9","role_capability":"all_access"},{"_id":"5d1efe9adedfe54a984f27fb","role_capability":"all_access"},{"_id":"5d1efeacdedfe54a984f27fd","role_capability":"all_access"}]},{"_id":"5d1efecededfe54a984f27ff","address":"","status":"not verified","email":"kizaru@kizaru.com","name":"kizaru","phone":"12345","business_id":[{"_id":"5d1efedededfe54a984f2801","role_capability":"all_access"},{"_id":"5d1efef6dedfe54a984f2803","role_capability":"all_access"}]}]; const res = arr.find(({ _id }) => _id == obj.account._id); console.log(res); 
 .as-console-wrapper { max-height: 100% !important; top: auto; } 

暫無
暫無

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

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