[英]Create object with dynamic property names based on strings
我有这个对象数组:
[
{
"id": 4,
"user_id": 1,
"business_id": 2,
"branch_id": 3,
"type": "service",
"item": "Typing",
"unitPrice": 100,
"bulkUnit": 20,
"bulkUnitPrice": 80,
"availableUnits": "NA",
"created_at": "2019-05-03 11:36:33",
"updated_at": "2019-05-03 11:36:33"
},
{
"id": 5,
"user_id": 1,
"business_id": 2,
"branch_id": 3,
"type": "service",
"item": "Printing",
"unitPrice": 70,
"bulkUnit": 50,
"bulkUnitPrice": 40,
"availableUnits": "NA",
"created_at": "2019-05-03 11:37:29",
"updated_at": "2019-05-03 11:37:29"
}
]
对于每个对象,我需要使用item
属性的值作为新对象中的属性名称,如下所示:
{
"Typing": null,
"Printing": null
}
您可以结合使用Array.prototype.map()和Object.fromEntries()来实现 。
const data = [ {"id":4,"user_id":1,"business_id":2,"branch_id":3,"type":"service","item":"Typing","unitPrice":100,"bulkUnit":20,"bulkUnitPrice":80,"availableUnits":"NA","created_at":"2019-05-03 11:36:33","updated_at":"2019-05-03 11:36:33"}, {"id":5,"user_id":1,"business_id":2,"branch_id":3,"type":"service","item":"Printing","unitPrice":70,"bulkUnit":50,"bulkUnitPrice":40,"availableUnits":"NA","created_at":"2019-05-03 11:37:29","updated_at":"2019-05-03 11:37:29"} ]; const result = Object.fromEntries(data.map(x => [x.item, null])); console.log(result)
您可以在每个元素上执行化简函数并生成一个对象。
const items = [{"id":4,"user_id":1,"business_id":2,"branch_id":3,"type":"service","item":"Typing","unitPrice":100,"bulkUnit":20,"bulkUnitPrice":80,"availableUnits":"NA","created_at":"2019-05-03 11:36:33","updated_at":"2019-05-03 11:36:33"},{"id":5,"user_id":1,"business_id":2,"branch_id":3,"type":"service","item":"Printing","unitPrice":70,"bulkUnit":50,"bulkUnitPrice":40,"availableUnits":"NA","created_at":"2019-05-03 11:37:29","updated_at":"2019-05-03 11:37:29"}]; const result = items.reduce((accumulator, currentValue) => { accumulator[currentValue.item] = null; return accumulator; }, {}); console.log(result);
您可以通过仅采用想要的属性并将此值作为计算的属性来将映射的对象分配给单个对象。
var data = [{ id: 4, user_id: 1, business_id: 2, branch_id: 3, type: "service", item: "Typing", unitPrice: 100, bulkUnit: 20, bulkUnitPrice: 80, availableUnits: "NA", created_at: "2019-05-03 11:36:33", updated_at: "2019-05-03 11:36:33" }, { id: 5, user_id: 1, business_id: 2, branch_id: 3, type: "service", item: "Printing", unitPrice: 70, bulkUnit: 50, bulkUnitPrice: 40, availableUnits: "NA", created_at: "2019-05-03 11:37:29", updated_at: "2019-05-03 11:37:29" }], result = Object.assign({}, ...data.map(({ item }) => ({ [item]: null }))); console.log(result);
只需遍历项目,然后抓住item
并将值推到新对象上即可:
const items = [ {"id":4,"user_id":1,"business_id":2,"branch_id":3,"type":"service","item":"Typing","unitPrice":100,"bulkUnit":20,"bulkUnitPrice":80,"availableUnits":"NA","created_at":"2019-05-03 11:36:33","updated_at":"2019-05-03 11:36:33"}, {"id":5,"user_id":1,"business_id":2,"branch_id":3,"type":"service","item":"Printing","unitPrice":70,"bulkUnit":50,"bulkUnitPrice":40,"availableUnits":"NA","created_at":"2019-05-03 11:37:29","updated_at":"2019-05-03 11:37:29"} ] let result = {} items.forEach(i => { result[i.item] = null }) console.log(result)
一种非常简单的方法:
<script> var oldJSON = '[{"id":4,"user_id":1,"business_id":2,"branch_id":3,"type":"service","item":"Typing","unitPrice":100,"bulkUnit":20,"bulkUnitPrice":80,"availableUnits":"NA","created_at":"2019-05-03 11:36:33","updated_at":"2019-05-03 11:36:33"},{"id":5,"user_id":1,"business_id":2,"branch_id":3,"type":"service","item":"Printing","unitPrice":70,"bulkUnit":50,"bulkUnitPrice":40,"availableUnits":"NA","created_at":"2019-05-03 11:37:29","updated_at":"2019-05-03 11:37:29"}]'; // Convert to object var oldJSONObj = JSON.parse(oldJSON); var newJSONObj = {} // Loop through & get the value for item and add it to new JSON for (var key in oldJSONObj) { if (oldJSONObj.hasOwnProperty(key)) { var val = oldJSONObj[key]["item"]; newJSONObj[val] = null; } } //newJSONObj contains the JSON you require document.write(JSON.stringify(newJSONObj)); </script>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.