как использовать optional chaining с массивами и функциями в javascript

Аватар пользователя Maksim Litvinov
Maksim Litvinov
14 февраля 2025

Optional chaining в JavaScript позволяет безопасно обращаться к свойствам объекта, даже если они могут быть undefined или null. Это особенно удобно при работе с массивами и объектами, где вложенные элементы могут быть не определены.

Работа с массивами

Предположим, у нас есть массив объектов, и мы хотим получить доступ к свойству вложенного объекта без опаски встретить ошибку типа "undefined is not a property".

let users = [
    { name: "Alice", age: 25, address: { city: "New York" } },
    { name: "Bob", age: 30 }
];

// Использование optional chaining для доступа к свойствам вложенного объекта
let city = users[0]?.address?.city;
console.log(city); // Выведет "New York"

let city2 = users[1]?.address?.city;
console.log(city2); // undefined

При использовании optional chaining, если какое-либо из свойств (в данном случае address или city) отсутствует в цепочке доступа, значение будет равно undefined, и в итоге не будет выброшено исключение.

Работа с функциями

Optional chaining также применим и к вызову функций. Это может быть полезно, если мы хотим вызвать функцию, которая может быть не определена.

let user = {
    name: "Alice",
    greet: function() {
        return "Hello, " + this.name;
    }
};

// Использование optional chaining для вызова функции
let message = obj.greet?.();
console.log(message); // => Hello, Alice

let obj2 = {
    name: "Bob"
};

let message2 = obj2.greet?.();
console.log(message2); // Выведет undefined, так как функция greet не определена в obj2

Optional chaining позволяет избежать ошибки при вызове метода, если он отсутствует у объекта. Таким образом, мы можем более безопасно обращаться к свойствам и методам объектов, что повышает надежность кода

1 0

Есть что добавить? Зарегистрируйтесь

или войдите в аккаунт

Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»

Курсы по программированию в Хекслете

Программирование

Веб-разработка

Разработка, верстка и деплой сайтов и веб-приложений, трудоустройство для разработчиков

Frontend-разработка

Разработка внешнего интерфейса сайтов и веб-приложений и верстка

Создание сайтов

Разработка сайтов и веб-приложений на JS, Python, Java, PHP и Ruby on Rails

Backend-разработка

Разработка серверной части сайтов и веб-приложений

Тестирование

Ручное тестирование и автоматизированное тестирование на JS, Python, Java и PHP

Аналитика данных

Сбор, анализ и интерпретация данных на Python

Интенсивные курсы

Интенсивное обучение для продолжающих

DevOps

Автоматизация настройки локального окружения и серверов, развертывания и деплоя

Математика для программистов

Обучение разделам математики, которые будут полезны при изучении программирования

Тест-драйв

JavaScript

Разработка сайтов и веб-приложений и автоматизированное тестирование на JS

Python

Веб-разработка, автоматическое тестирование и аналитика данных на Python

Java

Веб-разработка и автоматическое тестирование на Java

PHP

Веб-разработка и автоматическое тестирование на PHP

Ruby

Разработка сайтов и веб-приложений на Ruby on Rails

Go

Курсы по веб-разработке на языке Go

Верстка

HTML

Современная верстка с помощью HTML и CSS

SQL

Проектирование базы данных, выполнение SQL-запросов и изучение реляционных СУБД

Git

Система управления версиями Git, регулярные выражения и основы командой строки

Бесплатные курсы

Бесплатные курсы по тестированию, дата-аналитике, верстке, программированию на Python, Java, PHP и JavaScript.

Фреймворки

Базы данных