[英]JavaScript: Object destructuring dynamically via computed keys
我正在尝试编写一个咖喱函数dissoc,它接受一个prop和一个对象,并从该对象中删除键及其值。
这是有效的代码:
const dissoc = prop => obj => {
const result = {};
for (let p in obj) {
result[p] = obj[p];
}
delete result[prop];
return result;
};
现在,我认为可以通过使用计算属性 ,解构和rest运算符来简化代码:
const dissoc = prop => ({ [prop], ...obj}) => obj
但是此代码抛出:
Uncaught SyntaxError: Unexpected token ,
所以我尝试了:
const dissoc = prop => ({ prop, ...obj}) => obj
计算,但只返回不带prop的对象。
有没有办法动态地分解和/或简化此代码?
您需要一个目标变量,例如下划线作为未使用的变量/占位符的符号。
const dissoc = prop => ({ [prop]: _, ...obj}) => obj
JavaScript没有使用变量的概念,例如PHP带有$$variable
,其中$variable
的值被视为变量。 在这种情况下,您需要另一个变量,因为计算出的属性名称且没有实际变量,因此它不起作用。
也许值得一读: 对象属性分配模式[YDKJS:ES6&Beyond]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.