Saltar al contenido principal

@babel/plugin-transform-encadenamiento-opcional

Traducción Beta No Oficial

Esta página fue traducida por PageTurner AI (beta). No está respaldada oficialmente por el proyecto. ¿Encontraste un error? Reportar problema →

información

Este plugin está incluido en @babel/preset-env, dentro de ES2020

Ejemplo

Acceso a propiedades profundamente anidadas

JavaScript
const obj = {
foo: {
bar: {
baz: 42,
},
},
};

const baz = obj?.foo?.bar?.baz; // 42

const safe = obj?.qux?.baz; // undefined

// Optional chaining and normal chaining can be intermixed
obj?.foo.bar?.baz; // Only access `foo` if `obj` exists, and `baz` if
// `bar` exists

// Example usage with bracket notation:
obj?.["foo"]?.bar?.baz; // 42

Llamada a funciones profundamente anidadas

JavaScript
const obj = {
foo: {
bar: {
baz() {
return 42;
},
},
},
};

const baz = obj?.foo?.bar?.baz(); // 42

const safe = obj?.qux?.baz(); // undefined
const safe2 = obj?.foo.bar.qux?.(); // undefined

const willThrow = obj?.foo.bar.qux(); // Error: not a function

// Top function can be called directly, too.
function test() {
return 42;
}
test?.(); // 42

exists?.(); // undefined

Construcción de clases profundamente anidadas

JavaScript
const obj = {
foo: {
bar: {
baz: class {
},
},
},
};

const baz = new obj?.foo?.bar?.baz(); // baz instance

const safe = new obj?.qux?.baz(); // undefined
const safe2 = new obj?.foo.bar.qux?.(); // undefined

const willThrow = new obj?.foo.bar.qux(); // Error: not a constructor

// Top classes can be called directly, too.
class Test {
}
new Test?.(); // test instance

new exists?.(); // undefined

Eliminación de propiedades profundamente anidadas

Agregado en: v7.8.0

JavaScript
const obj = {
foo: {
bar: {},
},
};

const ret = delete obj?.foo?.bar?.baz; // true

Instalación

npm install --save-dev @babel/plugin-transform-optional-chaining

Uso

Mediante un archivo de configuración (Recomendado)

babel.config.json
{
"plugins": ["@babel/plugin-transform-optional-chaining"]
}

Mediante la CLI

Shell
babel --plugins @babel/plugin-transform-optional-chaining script.js

Mediante la API de Node

JavaScript
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-transform-optional-chaining"],
});

Opciones

loose

boolean, valor predeterminado: false.

Cuando es true, esta transformación simulará que document.all no existe y realizará comprobaciones de igualdad débil con null en lugar de comprobaciones de igualdad estricta tanto con null como con undefined.

precaución

Considera migrar a la suposición de alto nivel noDocumentAll.

babel.config.json
{
"assumptions": {
"noDocumentAll": true
}
}

Ejemplo

Entrada

JavaScript
foo?.bar;

Salida (noDocumentAll === true)

JavaScript
foo == null ? void 0 : foo.bar;

Salida (noDocumentAll === false)

JavaScript
foo === null || foo === void 0 ? void 0 : foo.bar;
consejo

Puedes leer más sobre cómo configurar opciones de plugins aquí

Referencias