Movatterモバイル変換


[0]ホーム

URL:


  1. Tecnología web para desarrolladores
  2. JavaScript
  3. Referencia de JavaScript
  4. Expresiones y operadores
  5. Encadenamiento opcional

Esta página ha sido traducida del inglés por la comunidad.Aprende más y únete a la comunidad de MDN Web Docs.

View in EnglishAlways switch to English

Encadenamiento opcional

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since ⁨julio de 2020⁩.

El operador deencadenamiento opcional?. permite leer el valor de una propiedad ubicada dentro de una cadena de objetos conectados sin tener que validar expresamente que cada referencia en la cadena sea válida. El operador?. funciona de manera similar a el operador de encadenamiento., excepto que en lugar de causar un error si una referencia escasi-nula (null oundefined), la expresión hace una evaluación de circuito corto con un valor de retorno deundefined. Cuando se usa con llamadas a funciones, devuelveundefined si la función dada no existe.

Esto da como resultado expresiones más cortas y simples cuando se accede a propiedades encadenadas dónde existe la posibilidad de que falte una referencia. También puede ser útil al explorar el contenido de un objeto cuando no hay una garantía conocida de qué propiedades se requieren.

Pruébalo

const adventurer = {  name: "Alice",  cat: {    name: "Dinah",  },};const dogName = adventurer.dog?.name;console.log(dogName);// Expected output: undefinedconsole.log(adventurer.someNonExistentMethod?.());// Expected output: undefined

Sintaxis

obj?.propobj?.[expr]arr?.[index]func?.(args)

Descripción

El operador de encadenamiento opcional proporciona una forma de simplificar el acceso a los valores a través de objetos conectados cuando es posible que una referencia o función seaundefined onull.

Por ejemplo, considere un objetoobj que tiene una estructura anidada. Sin encadenamiento opcional, buscar una subpropiedad profundamente anidada requiere validar las referencias intermedias, como:

js
let nestedProp = obj.first && obj.first.second;

Se confirma que el valor deobj.first no esnull (y no esundefined) antes de acceder al valor deobj.first.second. Esto evita el error que ocurriría si simplemente accediera aobj.first.second directamente sin probarobj.first.

Sin embargo, con el operador de encadenamiento opcional (?.), No tiene que probar explícitamente, ni realizar una evaluación de circuito corto basada en el estado deobj.first antes de intentar acceder aobj.first.second:

js
let nestedProp = obj.first?.second;

Al usar el operador?. en lugar de solo el., JavaScript sabe verificar implícitamente para asegurarse de queobj.first no esnull oundefined antes de intentar accederobj.first.second. Siobj.first esnull oundefined, la expresión hace una evaluación de circuito corto automáticamente y retornaundefined.

Esto es equivalente a lo siguiente, excepto que la variable temporal es de hecho no creada:

js
let temp = obj.first;let nestedProp = ((temp === null || temp === undefined) ? undefined : temp.second);

Encadenamiento opcional con llamadas a funciones

Puede usar el encadenamiento opcional cuando intente llamar a un método que puede no existir. Esto puede ser útil, por ejemplo, cuando se usa una API en la que un método podría no estar disponible, ya sea debido a la antigüedad de la implementación o debido a una característica que no está disponible en el dispositivo del usuario.

El uso de encadenamiento opcional con llamadas a funciones hace que la expresión regrese automáticamenteundefined en lugar de lanzar una excepción si no se encuentra el método:

js
let result = someInterface.customMethod?.();

Nota:Si hay una propiedad con ese nombre y que no es una función, usar?. aún levantará una excepciónTypeError (x.y is not a function).

Manejo de callbacks opcionales o manejadores de eventos

Si utiliza callbacks o métodos de recuperación de un objeto conuna asignación de desestructuración, es posible que tenga valores inexistentes que no puede llamar como funciones a menos que haya probado su existencia. Usando?., Puede evitar esta prueba adicional:

js
// Escrito a partir de ES2019function doSomething(onContent, onError) {  try {    // ... hacer algo con los datos  } catch (err) {    if (onError) {      // Probando si onError realmente existe      onError(err.message);    }  }}
js
// Usando encadenamiento opcional con llamado de funcionesfunction doSomething(onContent, onError) {  try {    // ... hacer algo con los datos  } catch (err) {    onError?.(err.message); // Sin excepción si onError esta undefined  }}

Encadenamiento opcional con expresiones

También puede usar el operador de encadenamiento opcional al acceder a propiedades con una expresión usandola notación de corchetes:

js
let nestedProp = obj?.["prop" + "Name"];

El encadenamiento opcional no es válido al lado izquierdo de una asignación

js
let object = {};object?.property = 1; // Uncaught SyntaxError: Invalid left-hand side in assignment

Acceso a elementos de un arreglo con encadenamiento opcional

js
let arrayItem = arr?.[42];

Ejemplos

Ejemplo básico

Este ejemplo busca el valor de la propiedadname para el miembrobar en un mapa cuando no existe dicho miembro. El resultado es por lo tanto esundefined.

js
let myMap = new Map();myMap.set("foo", { name: "baz", desc: "inga" });let nameBar = myMap.get("bar")?.name;

Evaluación de circuito corto

Cuando se usa el encadenamiento opcional con expresiones, si el operando izquierdo esnull oundefined, la expresión no se evaluará. Por ejemplo:

js
let potentiallyNullObj = null;let x = 0;let prop = potentiallyNullObj?.[x++];console.log(x); // 0 como x no se incrementó

Apilando el operador de encadenamiento opcional

Con estructuras anidadas, es posible usar encadenamiento opcional varias veces:

js
let customer = {  name: "Carl",  details: {    age: 82,    location: "Paradise Falls", // "detailed address" es desconocida  },};let customerCity = customer.details?.address?.city;// … esto también funciona con la función opcional de encadenamientolet duration = vacations.trip?.getTime?.();

Combinando con el operador de fusión nulo

Eloperador de fusión nulo se puede usar después del encadenamiento opcional para generar un valor predeterminado cuando no se encontró ninguno:

js
let customer = {  name: "Carl",  details: { age: 82 },};const customerCity = customer?.city ?? "Unknown city";console.log(customerCity); // Unknown city

Especificaciones

Specification
ECMAScript® 2026 Language Specification
# prod-OptionalExpression

Compatibilidad con navegadores

Ver también

Help improve MDN

Learn how to contribute

This page was last modified on byMDN contributors.


[8]ページ先頭

©2009-2025 Movatter.jp