JS 对象数组 属性 初始化器/可选链接
JS Object array property initializer / optional chaining
初始化对象数组属性然后推送值似乎是一个两步法。 ES6 中是否有最佳的单行方法?该问题的示例在下面的 appendError(prop, error)
方法中。
问题:
JS或lodash是否有一行或更简洁的方法?
未来的可选链似乎解决了这个问题,但今天有解决方案吗? PHP 允许 $array[prop][] = val;
class Errors {
constructor(fields ) {
this.errors = {};
}
/**
* Clear one or all error fields.
*
* @param {string} prop | example: "email"
* @param {string} error | example: "Invalid email"
*/
appendError(prop, error) {
/* Set key and empty array if property doest exist */
if (!this.has(prop)) this.errors[prop] = [];
/* then Push value */
this.errors[prop].push(error);
}
/**
* Determine if an errors exists for the given field.
*
* @param {string} prop
*/
has(prop) {
return this.errors.hasOwnProperty(prop);
}
}
您可能会为此滥用 ||
:
this.errors[prop]?.push(error) || (this.errors[prop] = [error]);
你可以这样写:
appendError(prop, error) {
(this.error[prop] = this.error[prop]||[]) && this.error[prop].push(error) && this.error[prop];
}
你可以使用Logical nullish assignment (??=)分配一个空数组,如果属性值id undefined
:
(this.errors[prop] ??= []).push(error);
示例:
class Errors {
constructor(fields) {
this.errors = {};
}
appendError(prop, error) {
(this.errors[prop] ??= []).push(error);
}
}
const errors = new Errors;
errors.appendError('a', 'a');
errors.appendError('a', 'b');
console.log(errors.errors);
初始化对象数组属性然后推送值似乎是一个两步法。 ES6 中是否有最佳的单行方法?该问题的示例在下面的 appendError(prop, error)
方法中。
问题:
JS或lodash是否有一行或更简洁的方法?
未来的可选链似乎解决了这个问题,但今天有解决方案吗? PHP 允许 $array[prop][] = val;
class Errors {
constructor(fields ) {
this.errors = {};
}
/**
* Clear one or all error fields.
*
* @param {string} prop | example: "email"
* @param {string} error | example: "Invalid email"
*/
appendError(prop, error) {
/* Set key and empty array if property doest exist */
if (!this.has(prop)) this.errors[prop] = [];
/* then Push value */
this.errors[prop].push(error);
}
/**
* Determine if an errors exists for the given field.
*
* @param {string} prop
*/
has(prop) {
return this.errors.hasOwnProperty(prop);
}
}
您可能会为此滥用 ||
:
this.errors[prop]?.push(error) || (this.errors[prop] = [error]);
你可以这样写:
appendError(prop, error) {
(this.error[prop] = this.error[prop]||[]) && this.error[prop].push(error) && this.error[prop];
}
你可以使用Logical nullish assignment (??=)分配一个空数组,如果属性值id undefined
:
(this.errors[prop] ??= []).push(error);
示例:
class Errors {
constructor(fields) {
this.errors = {};
}
appendError(prop, error) {
(this.errors[prop] ??= []).push(error);
}
}
const errors = new Errors;
errors.appendError('a', 'a');
errors.appendError('a', 'b');
console.log(errors.errors);