如何用条件进行对象解构?

pes*_*tov 4 javascript destructuring ecmascript-6

所以我有:

// some function that returns two arrays ..
getArrays() {
  return {
    arr1: [...],
    arr2: [...]
  };
}

// and then ..
let arr1 = [];
let arr2 = [];
if (someCondition) {
  { arr1, arr2 } = getArrays();
}

// here we expect arrays, even if they are empty ..
Run Code Online (Sandbox Code Playgroud)

当然,这会引发错误.这甚至可能吗?

PS:我可以使用默认值并直接调用该函数,但仍然 - 我认为它应该是可能的.

Ori*_*ori 7

一种解决方案是用括号包装解构表达式:

// some function that returns two arrays ..
function getArrays() {
  return {
    arr1: [1],
    arr2: [2]
  };
}
const someCondition = true;
let arr1 = [];
let arr2 = [];

if (someCondition) {
  ({ arr1, arr2 } = getArrays());
}

console.log(arr1, arr2);
Run Code Online (Sandbox Code Playgroud)

另一个解决方案是将条件移动到getArrays()函数,如果条件false返回两个空数组:

const getArrays = (condition) =>
  condition ? 
    { arr1: [1], arr2: [2] }
    :
    { arr1: [], arr2: [] };

const someCondition = true;
const { arr1, arr2 } = getArrays(someCondition);

console.log(arr1, arr2);
Run Code Online (Sandbox Code Playgroud)

您还可以使用函数外部的条件和三元组:

const getArrays = () => ({ arr1: [1], arr2: [2] });

const someCondition = true;
const { arr1, arr2 } = someCondition ? getArrays() : { arr1: [], arr2: [] };

console.log(arr1, arr2);
Run Code Online (Sandbox Code Playgroud)