Если ты до сих пор пишешь так:
const name = user.name; const email = user.email; const age = user.age;
то деструктуризация покажется тебе супер способностью.
ES6 ввел синтаксис деструктурирующего присваивания — лаконичный способ распаковки значений из массивов и объектов в отдельные переменные. Это одна из тех фич, начав использовать которые, ты удивишься, как раньше без нее жил.
Разберем 12 паттернов: от базовых до продвинутых.
Деструктуризация объектов
Паттерн 1. Базовая деструктуризация объекта
const user = { name: "Ivan", age: 28, email: "ivan@proweb63.ru", role: "developer" }; // Устаревший подход const name = user.name; const age = user.age; const email = user.email; // Деструктуризация. Делай так const { name, age, email } = user; console.log(name); // "Ivan" console.log(age); // 28 console.log(email); // "ivan@proweb63.ru"
Паттерн 2. Переименование переменных (aliasing)
Исходное имя свойства не подходит для переменной, или нужно дать более чистое имя:
const apiResponse = { user_name: "Ivan", user_age: 28 // ... }; // Переименовываем user_name → userName const { user_name: userName, user_age: userAge } = apiResponse;
Паттерн 3. Значения по умолчанию
const config = { theme: "dark" }; const { theme, lang = "ru" } = config; console.log(lang); // "ru" — значение по умолчанию
Паттерн 4. Деструктуризация во вложенных объектах
const user = { name: "Ivan", address: { city: "Москва", zip: "000001" } }; const { address: { city, zip } } = user; console.log(city); // "Москва"
Паттерн 5. Деструктуризация параметров функции
// Было function displayUser(user) { console.log(`${user.name} (${user.age})`); } // Стало function displayUser({ name, age }) { console.log(`${name} (${age})`); } // Вызов остаётся тем же: displayUser(user)
Деструктуризация массивов
Паттерн 6. Базовая деструктуризация массива
const colors = ["red", "green", "blue"]; const [first, second] = colors; console.log(first); // "red" console.log(second); // "green"
Паттерн 7. Пропуск элементов (skip pattern)
const [, second, , fourth] = [1, 2, 3, 4, 5]; console.log(second); // 2 console.log(fourth); // 4
Паттерн 8. Деструктуризация + rest-оператор
const nums = [10, 20, 30, 40, 50]; const [head, ...tail] = nums; console.log(head); // 10 console.log(tail); // [20, 30, 40, 50]
Паттерн 9. Значения по умолчанию в массивах
const input = ["value1"]; const [a = "defaultA", b = "defaultB"] = input; console.log(a); // "value1" console.log(b); // "defaultB"
Продвинутые паттерны (комбинации и частные случаи)
Паттерн 10. Swap (обмен значений) без временной переменной
let x = 1, y = 2; [x, y] = [y, x]; console.log(x, y); // 2 1
Паттерн 11. Деструктуризация возвращаемого значения функции
function getCoordinates() { return { lat: 40.7128, lng: -74.0060 }; } const { lat, lng } = getCoordinates();
Паттерн 12. Смешанная деструктуризация (объект + массив)
const response = { status: 200, data: { items: [{ id: 1, name: "A" }, { id: 2, name: "B" }] } }; const { data: { items: [firstItem, secondItem] } } = response; console.log(firstItem); // { id: 1, name: "A" }
Ключевые выводы для разработчика
Что дает использование деструктуризации | Технический смысл |
|---|---|
Снижение дублирования кода | DRY-принцип |
Улучшение читаемости | Self-documenting code |
Меньше промежуточных переменных | Меньше мусора в лексическом окружении |
Четкая спецификация зависимостей от структуры данных | Явное объявление контракта |
Единый стиль для объекта/массива | Предиктивность |
Рекомендация: применяй деструктуризацию везде, где ты обращаешься к свойствам объекта более одного раза или хочешь явно показать, какие поля из входящего объекта использует функция. Исключение — когда нужна ссылка на сам родительский объект.
Если вы до сих пор пишете
const tmp = obj.prop— этот материал для вас. Переходите на ES6+ и пишите код, который не стыдно показать на код-ревью.
А какие приемы работы с деструктуризацией или другими фичами ES6+ вы используете ежедневно? Возможно, у вас есть кейс, где деструктуризация помогла избежать бага или существенно сократить код? Поделитесь примерами в комментариях — интересно посмотреть на реальный опыт.
