ES6-如何在不循环的情况下更改OBJ道具名称



在es6中我有一个像

的数组
[{id:0,name:"a"},{id:1,name:"b"}]

我想更改其道具名称而不映射或循环

 [{value:0,label:"a"},{value:1,label:"b"}]

我可以使用类似函数的别名吗?或其他任何选择?

首先感谢

函数中的别名示例:功能(ID:LABEL({...在此功能标签中为ID}

如果条目数量可变,则可以使用代理

var thing = [{id:0,name:"a"},{id:0,name:"b"}]
var newThing = new Proxy(thing, {
    get: (target, name, receiver) => !isNaN(parseInt(name)) ? ({value:target[name].id, label:target[name].name}) : target[name]
});
console.log(newThing[0]); //Object { value: 0, label: "a" }
newThing.forEach(item => console.log(item));
//Object { value: 0, label: "a" }
//Object { value: 0, label: "b" }

如果value是序列位置(如您的示例输入/输出所暗示的(

var newThing = new Proxy(thing, {
    get: (target, name, receiver) => !isNaN(parseInt(name)) ? ({value:parseInt(name), label:target[name].name}) : target[name]
});

您可以使用对象破坏,Array.prototype.shift()

let arr = [{id:0,name:"a"},{id:0,name:"b"}];
let res = [];
([{id:res[res.length], name:res[res.length]}
, {id:res[res.length], name:res[res.length]}] = arr);
arr = [{value:res.shift(), label:res.shift()}
      , {value:res.shift() + 1, label:res.shift()}];
console.log(arr);

相关内容

最新更新