Операції spread і rest
Spread
Оператор spread використовують для розширення, розпакування чи копіювання значень масивів, об'єктів або інших ітерабельних об'єктів в нові структури даних. Його синтаксис - це три крапки ... перед структурою, яку потрібно "розпорошити".
Операція spread для масивів
За допомогою ... (три крапки) можна "розпорошити" елементи масиву.
let array1 = [1, 2, 3];
let array2 = [...array1, 4, 5, 6];
console.log(array2); // Виведе: [1, 2, 3, 4, 5, 6]Тобто ця операція розклала array1 на його складові елементи і вставила в нову структуру array2 у вказане місце (не обовʼязково напочатку).
До введення в стандарт цієї операції використовувати методи slice() і concat().
Операція spread для об'єктів
Так само, за допомогою ... (три крапки) можна "розпорошити" властивості об'єкту.
let object1 = { a: 1, b: 2 };
let object2 = { ...object1, c: 3, d: 4 };
console.log(object2); // Виведе: { а: 1, b: 2, с: 3, d: 4 }Якщо розпорошувати обʼєкти і будуть властивості з одноковою назвою, то буде перезаписана і застосована остання вказана властивість. Цей підхід часто використовують на практиці.
Передача аргументів функції
Spread також можна використовувати для передачі аргументів у функцію.
У прикладі "розпорошується" масив у переданих аргументах функції - кожен елемент це окремий аргумент. тобто summ(...[1, 2, 3]) це те ж саме, що і summ(1, 2, 3).
Rest
Оператор rest використовують для збору аргументів в масив або збору лишніх аргументів в функцію у вигляді масиву.
Використання rest для збору аргументів функції в масив
У цьому прикладі ...elseArgs збирає всі аргументи, що залишилися після a і b, в масив elseArgs. Тобто операція rest збирає решту усіх аргументів, а тому повинна бути останньою у підписі функції, інакше виникне помилка.
Можна винести всі аргументи в масив.
Ім'я параметра може бути будь-яким. Найчастіше його називають args, restArgs або otherArgs - скорочено від arguments.
Last updated