2017-02-21 27 views
2

我现在面临一个特殊的问题,我需要改变像一个对象的结构:更改对象结构和性能在Javascript

customerPayload = { 
     name: 'Name must remain', 
     billing_address_street: 'Electric Avenue', 
     billing_address_number: 222, 
     shipping_address_street: 'Avenue 1', 
     shipping_address_number: 1337 
    }; 

成这样:

customerPayload = { 
     name: 'Name must remain', 
     billing_address: { 
      street: 'Electric Avenue', 
      number: 222 
     }, 
     shipping_address: { 
      street: 'Avenue 1', 
      number: 1337 
     } 
    }; 

我想是这样的:

for (var p in customerPayload) { 
     if (customerPayload.hasOwnProperty(p)) { 
      if (p.includes('billing')) {  
       var b = p.substr(0, 15) + '.' + p.substr(15 + 1);   
       var bAddress = b.split('.')[0]; 
       var childProp = b.split('.')[1]; 
       newCustomerPayload[bAddress] = { 
        [childProp]: customerPayload[p] 
       }; 
      } 
      // else if shipping ... same thing 
     } 
    } 

但结果是只有最后更改的属性的对象:

customerPayload = { 
    billing_address: { 
     number: 222 
    }, 
    shipping_address: { 
     street: 'Avenue 1' 
    } 
}; 

请帮忙吗?

+1

为什么不这样做手工需要4行代码,我认为! –

+1

对象'customerPayload'是我的服务器中的请求体,我无法更改属性名称=/ – gcfabri

回答

3

您可以使用reduce()返回新的对象。

var data = { 
 
    name: 'Name must remain', 
 
    billing_address_street: 'Electric Avenue', 
 
    billing_address_number: 222, 
 
    shipping_address_street: 'Avenue 1', 
 
    shipping_address_number: 1337 
 
}; 
 

 
var result = Object.keys(data).reduce(function(r, e) { 
 
    if (!e.match('_')) r[e] = data[e] 
 
    else { 
 
    var key = e.split(/_([^_]*)$/) 
 
    if (!r[key[0]]) r[key[0]] = {} 
 
    r[key[0]][key[1]] = data[e] 
 
    } 
 
    return r; 
 
}, {}) 
 

 
console.log(result)

+0

谢谢,这个工作完美。 – gcfabri

+0

什么是分割字符串的规则?我不熟悉正则表达式。这也破坏了一个名为'invoice_template'的属性,并且应该保持它在新对象上的状态。 – gcfabri

+0

它在最后'_'打断字符串。 –