使用子数组过滤对象

时间:2019-01-31 18:21:14

标签: javascript react-native

嗨,我是想筛选此对象可获得以下对象的结果。某些对象在子数组中可能只有一个子编号。我已经加入一个样品和所需的结果。

//Curently have 
Object {
"contactType": "person",
"firstName": "Jame Bond",
 "id": "05434909-468F-4AF4-wfde-000000000:ABPerson",
"imageAvailable": false,
 "key": undefined,
"name": "Jame Bond",
 "phoneNumbers": Array [
  Object {
   "countryCode": "us",
    "digits": "+14255556668",
    "id": "53109855-4BA3-4A29-A65C-05B60ED299FA",
    "label": "‎old number",
    "number": "+1 (424) 555-0000",
  },
 Object {
    "countryCode": "gb",
  "digits": "+44712345678",
    "id": "37D77251-39E3-488D-9832-102E7B907E24",
     "label": "mobile",
    "number": "+44712345678",
   },
],
},

//need 
Object {
"name": "James Bond"
  Object {
"digits1": "+14255556668",
"digits2": "+44712345678" // if exists! 
  }
}

有什么建议吗?

1 个答案:

答案 0 :(得分:1)

喜欢吗?

const { 
  name, 
  phoneNumbers: [ 
    // ':' equals as, and '=' means default value, when prop doesn't exist
    // could be anything you want
    { digits: digits1 }, 
    { digits: digits2 = null } 
  ],
} = yourObject;
const newObject = { name, { digits1, ...digits2 } };

我们只是在分解对象,然后根据该变量创建一个新对象。您可以找到更多信息here

如果电话号码可能非常正确,我建议使用以下代码。

const { name, phoneNumbers } = yourObject;
const allDigits = phoneNumbers.map(({ digits }, i) => ({[`digits${i}`]: digits}));
const newObject = Object.assign({ name }, ...allDigits);