为了账号安全,请及时绑定邮箱和手机立即绑定

重命名对象数组中的嵌套键JS

重命名对象数组中的嵌套键JS

ABOUTYOU 2022-05-26 10:28:12
使用 JS 我正在尝试重命名canBook -> quantity和variationsEN -> variations嵌套键valueEN -> valuevar prod = [{    price: 10,    canBook: 1}, {    price: 11,    canBook: 2,    variationsEN: [{        valueEN: 1    }, {        valueEN: 2    }]}]我能够重命名键,但我不知道如何重命名嵌套的键:valueENprod.map(p => ({    quantity: p.canBook, variations:p.variationsEN}))
查看完整描述

3 回答

?
MMTTMM

TA贡献1869条经验 获得超4个赞

只需再次应用相同的技巧。代替:

variations:p.variationsEN

和:

variations:(p.variationsEN || []).map(q => ({ value: q.valueEN }))

另外|| []是处理源对象中不存在该属性的情况。在这种情况下,会为其生成一个空数组。


查看完整回答
反对 回复 2022-05-26
?
墨色风雨

TA贡献1853条经验 获得超6个赞

您可以对重命名属性的对象采用递归方法并构建新对象或数组。


function rename(value) {

    if (!value || typeof value !== 'object') return value;

    if (Array.isArray(value)) return value.map(rename);

    return Object.fromEntries(Object

        .entries(value)

        .map(([k, v]) => [keys[k] || k, rename(v)])

    );

}


var keys = { canBook: 'quantity', variationsEN: 'variations', valueEN: 'value' },

    prod = [{ price: 10, canBook: 1 }, { price: 11, canBook: 2, variationsEN: [{ valueEN: 1 }, { valueEN: 2 }] }],

    result = rename(prod);


console.log(result);

.as-console-wrapper { max-height: 100% !important; top: 0; }


查看完整回答
反对 回复 2022-05-26
?
元芳怎么了

TA贡献1798条经验 获得超7个赞

如果它确实是 JSON(如您的标签所示),例如您从服务器获取它作为字符串,您可以使用 reviver函数,例如:


var prod = JSON.parse(prodJSON, function (k, v) {

 if (k === "canBook") {

   this["quantity"] = v

 } else {

   return v

 }

});

(当然,如果您从 JS 对象而不是 JSON 字符串开始,您总是可以进行字符串化,但在这种情况下,这将是一种矫枉过正)


查看完整回答
反对 回复 2022-05-26
  • 3 回答
  • 0 关注
  • 144 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号