JavaScript:对象通过计算键动态解构
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;
};
现在,我认为可以通过使用 computed properties、解构和其余运算符将其编写得更简洁:
const dissoc = prop => ({ [prop], ...obj}) => obj
但是这段代码抛出:
Uncaught SyntaxError: Unexpected token ,
所以我尝试了:
const dissoc = prop => ({ prop, ...obj}) => obj
计算,但只是 returns 没有 prop 的对象。
有没有办法动态解构和/或简化此代码?
您需要一个目标变量,例如下划线作为未使用的符号 variable/placeholder。
const dissoc = prop => ({ [prop]: _, ...obj}) => obj
Javascript没有使用可变变量的概念,就像PHP和$$variable
一样,其中$variable
的值被当作变量。在这种情况下,您需要另一个变量,因为 computed property name 并且没有真正的变量,它不起作用。
也许值得一读:Object property assignment pattern [YDKJS: ES6 & Beyond]
我正在尝试编写一个柯里化函数 dissoc,它接受一个 prop 和一个对象,并从对象中删除键及其值。
这是有效的代码:
const dissoc = prop => obj => {
const result = {};
for (let p in obj) {
result[p] = obj[p];
}
delete result[prop];
return result;
};
现在,我认为可以通过使用 computed properties、解构和其余运算符将其编写得更简洁:
const dissoc = prop => ({ [prop], ...obj}) => obj
但是这段代码抛出:
Uncaught SyntaxError: Unexpected token ,
所以我尝试了:
const dissoc = prop => ({ prop, ...obj}) => obj
计算,但只是 returns 没有 prop 的对象。
有没有办法动态解构和/或简化此代码?
您需要一个目标变量,例如下划线作为未使用的符号 variable/placeholder。
const dissoc = prop => ({ [prop]: _, ...obj}) => obj
Javascript没有使用可变变量的概念,就像PHP和$$variable
一样,其中$variable
的值被当作变量。在这种情况下,您需要另一个变量,因为 computed property name 并且没有真正的变量,它不起作用。
也许值得一读:Object property assignment pattern [YDKJS: ES6 & Beyond]