DEV Community

Mesaque Francisco
Mesaque Francisco

Posted on • Originally published at linkedin.com

[pt-BR] ES2020: Optional chaining operator

Muitas novidades são esperadas com a chegada do ES2020. Uma delas que veio para simplificar a vida e diminuir a quantidade de código que temos que escrever é o operador de encadeamento opcional ?. - Optional chaining em inglês.

O funcionamento dele é similar ao do operador de encadeamento ., exceto que ao invés de causar um erro ao tentar acessar uma propriedade de uma referência vazia (null ou undefined), a expressão irá retornar undefined.

Isso pode ser muito util ao explorar conteúdo de um objeto onde não se tem garantia de que as propriedades são obrigatórias.

Exemplo

const player = {
  name: 'John',
  weapon: {
    name: 'sword',
  },
};

// Correto, porém verboso
let clothingName;
if (player != null && player.clothing != null) {
  clothingName = player.clothing.name;
}
console.log(cloathingName);

// Usando optional chaining
const clothingName = player.clothing?.name;
console.log(cloathingName); // expected output: undefined

// Correto, porém verboso
let value;
if (player != null && typeof player.someNonExistentMethod === 'function') {
  value = player.someNonExistentMethod();
}
console.log(value);

// Usando optional chaining
console.log(player.someNonExistentMethod?.()); // expected output: undefined
Enter fullscreen mode Exit fullscreen mode

Sintaxe

object?.prop;
object?.[expression];
arr?.[index];
func?.(args);
Enter fullscreen mode Exit fullscreen mode

O novo operador de encadeamento opcional ajuda reduzir a quantidade de código escrita, simplificando a leitura e manutenção.

Junto com o optional chaining operator receberemos o Nullish coalescing operator, mas isso é assunto para um post futuro.

Top comments (0)