¿Cómo definir una matriz con elementos condicionales?

Resuelto Manu Schiller asked hace 7 años • 14 respuestas

¿Cómo puedo definir elementos de matriz condicional? Quiero hacer algo como esto:

const cond = true;
const myArr = ["foo", cond && "bar"];

Esto funciona como se esperaba y da como resultado, ["foo", "bar"]pero si lo configuro cond, falseobtengo el siguiente resultado:["foo", false]

¿Cómo puedo definir una matriz con un elemento condicional?

Manu Schiller avatar Jul 04 '17 21:07 Manu Schiller
Aceptado

Puede distribuir una matriz dentro de una matriz, para mantener limpia la matriz de elementos, cuando la condición es false.

Así es como puedes hacerlo :

// Will result in ['foo', 'bar']
const items = [
  'foo',
  ... true ? ['bar'] : [],
  ... false ? ['falsy'] : [],
]

console.log(items)
Expandir fragmento

Explicaciones :

Como puede ver, el operador ternario siempre devuelve una matriz.

Si la condición es true, entonces devuelve ['bar']; en caso contrario, una matriz vacía [].

Después de eso, distribuimos ...la matriz resultante (de la operación ternaria) y los elementos de la matriz se envían a la matriz principal.

Si no hay ningún elemento de la matriz (cuando la verificación ternaria es false), entonces no se enviará nada, que es nuestro objetivo.


En otra respuesta expliqué la misma idea, pero para objetos. Puedes consultarlo también aquí .

Jordan Enev avatar Dec 12 '2017 11:12 Jordan Enev

yo haría esto

[
  true && 'one',
  false && 'two',
  1 === 1 && 'three',
  1 + 1 === 9 && 'four'
].filter(Boolean) // ['one', 'three']

Tenga en cuenta que esto también eliminará los valores falsos , como las cadenas vacías.

Michael Bergquist Suarez avatar Jan 26 '2018 15:01 Michael Bergquist Suarez

Si realmente desea mantenerlo como una sola línea, puede usar:

const cond = true;
const myArr = ["foo"].concat(cond ? ["bar"] : []);
James Thorpe avatar Jul 04 '2017 14:07 James Thorpe
const cond = false;
const myArr = ["foo", cond ? "bar" : null].filter(Boolean);

console.log(myArr)

Resultará en ["foo"]

Westman avatar May 27 '2020 07:05 Westman