簡體   English   中英

根據JavaScript中的條件合並兩個嵌套的JSON對象

[英]Merging two nested JSON objects based on conditionals in javascript

我試圖弄清楚如何合並兩個JSON對象並基於條件創建合並對象。

我想遍歷leadlistArray,獲取每個條目的rules.id,並將其與rulesArray進行匹配。 最終結果應該是finalArray。

leadlistArray = {
 "status": "success",
 "data": {
  "leadlists": [
   {
    "rules": [
     {
      "$oid": "53866d4d1fd21c3cc41f52da"
     }
    ],
    "name": "List 1: only general rule"
   },
   {
    "rules": [
     {
      "$oid": "53866d4d1fd21c3cc41f52da"
     },
     {
      "$oid": "53866d9c1fd21c3cc79bf7ce"
     },
     {
      "$oid": "53866d9c1fd21c3cc79bf2cd"
     }
    ],
    "name": "List 2: general and web-based rule"
   },
   {
    "rules": [
     {
      "$oid": "53866d9c1fd21c3cc79bf7ce"
     }
    ],
    "name": "List 3: only web-based rule"
   }
  ]
 }
}

規則數組:

rulesArray = {
 "status": "success",
 "data": {
  "rules": [
   {
    "description": "optimizely no!",
    "start_time": "",
    "values": [
     "optimizely"
    ],
    "end_time": "",
    "operator": "",
    "_id": {
     "$oid": "53866d4d1fd21c3cc41f52da"
    },
    "type": 0,
    "condition": 1
   },
   {
    "description": "google_plus no!",
    "start_time": "",
    "values": [
     "google_plus"
    ],
    "end_time": "",
    "operator": "",
    "_id": {
     "$oid": "53866d9c1fd21c3cc79bf2cd"
    },
    "type": 1,
    "condition": 1
   },
   {
    "description": "google_plus yes!",
    "start_time": "",
    "values": [
     "google_plus"
    ],
    "end_time": "",
    "operator": "",
    "_id": {
     "$oid": "53866d9c1fd21c3cc79bf7ce"
    },
    "type": 1,
    "condition": 0
   }
  ]
 }
}

對於每個列表,finalArray應按規則類型對規則描述進行分組:

finalArray = [
    {'name': 'List 1: only general rule'
    ,'rules':
        {0: [
            {'description': 'optimizely no!'}
        ]}
    },
    {'name': 'List 2: general and web-based rule'
    ,'rules': 
        {0: [
            {'description': 'optimizely no!'}
        ], 1: [
            {'description': 'google_plus yes!'},
            {'description': 'google_plus no!'}
        ]}
    },
    {'name': 'List 3: only web-based rule'
    ,'rules': {
        1: [
            {'description': 'google_plus yes!'}
        ]}
    }
]

試試這個http://jsfiddle.net/eN52v/

var rules = rulesArray.data.rules
    .reduce(function(acc, item){
        return acc[item._id.$oid] = {
            description: item.description, 
            type: item.type}, acc; 
    }, {}), //cache rules by id to avoid array lookups.

    finalArray = leadlistArray.data.leadlists.map(function(item) {
        return {
            name: item.name, 
            rules: item.rules.reduce(function(acc, rule){ //Why not an array?
                var ruleDesc = rules[rule.$oid],
                    type = ruleDesc.type;

                (acc[type] || (acc[type] = [])).push({description: ruleDesc.description});
                return acc;}, {})    
        }});

暫無
暫無

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

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