3 практических примера использования деструктурирования в JavaScript
- пятница, 21 июня 2019 г. в 00:16:03
Вы, наверное, уже знакомы с деструктурированием в JavaScript. Оно пришло к нам в 2015 году в спецификации ES6, но если вам нужно освежить знания, то на сайте Mozilla можно почитать большую подробную статью, как это всё работает.
Но знать как работает совсем не то же, что знать как использовать. Вот три паттерна, которые помогут вам сделать код чище, надёжнее и читаемее!
Именованные аргументы это альтернативный позиционным аргументам путь обработки параметров функции. Вместо того, чтобы указывать аргументы в строго определённом порядке, просто указывайте их имя. В Питоне, например, это выглядит так:
def sum(a=1,b=2,c=3):
return a+b+c
sum(b=5,a=10)
Видите? Порядок не важен, если вы явно указали имя параметра. Преимуществами по сравнению с позиционными аргументами является то, что:
Хотя нативно именованные аргументы в JavaScript не поддерживаются, мы можем использовать паттерн деструктурирования, чтобы добиться всех трёх преимуществ выше. Вот таким будет прошлый пример уже на JavaScript:
function sum({a = 1, b = 2, c = 3}) {
return a + b + c
}
sum({b: 10, a: 5}) // 5 + 10 + 3 = 18
Все цели достигнуты: можно не указывать c, порядок теперь не важен, и аргументы сопровождаются своими именами. Всё это возможно именно благодаря деструктурированию.
Часто в ответе сервера нам интересен только блок данных или даже только одно конкретное значение из этого блока. Если это ваш случай, используйте деструктурирование, чтобы игнорировать всё остальное, что сервер обычно присылает. Пример:
function mockServerCall () {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve({
'status': 200,
'content-type': 'application/json',
'data' : {
dataOfInterest: 42
}
})
}, 250)
})
}
mockServerCall()
.then(({data: { dataOfInterest = 100 }}) => {
console.log(dataOfInterest) // 42 (но по дефолту будет 100)
})
Этот паттерн позволяет выдёргивать интересующие нас данные по мере парсинга аргументов. А возможность настроить дефолтные значения вы получаете бонусом. Что плавно подводит нас к следующему паттерну...
Если переменной не существует в пространстве имён, нам часто нужно установить ей значение по-умолчанию.
До прихода деструктурирования вы могли делать что-то типа этого:
// старый способ установки дефолтных значений
var nightMode = userSettings.nightMode || false
Но такой подход потребует по строчке кода на каждое присвоение. Деструктурирование же позволит сделать всё одним махом:
const userSettings = {nightMode: true, fontSize: 'large'}
const {
nightMode = false,
language = 'en',
fontSize = 'normal'
} = userSettings
console.log(nightMode) // true
console.log(language) // 'en'
console.log(fontSize) // 'large'
Этот паттерн можно применять для установки состояния компонентов React!
Надеюсь, эти паттерны вам пригодятся! Чтобы почитать больше о деструктурировании переходите по ссылкам ниже (информация на английском — прим. перев.):