Operator spread i iteratory w JavaScript
Operator spread rozkłada dowolny obiekt,
który ma iterator. Przy tym będzie
brany iterator domyślny. Spójrzmy
na przykładzie. Niech mamy
następującą kolekcję Map:
let map = new Map();
map.set('a', 1);
map.set('b', 2);
map.set('c', 3);
Domyślnie przy rozkładaniu otrzymamy dwuwymiarową tablicę:
let arr = [...map];
console.log(arr); // [['a', 1], ['b', 2], ['c', 3]]
Aby otrzymać tablicę kluczy, rozłóżmy odpowiedni iterator:
let arr = [...map.keys()];
console.log(arr); // ['a', 'b', 'c']
Podobnie postąpimy, aby otrzymać tablicę wartości:
let arr = [...map.values()];
console.log(arr); // [1, 2, 3]
Rozłóż spreadem następujący obiekt:
let obj = {
a: 1,
b: 2,
c: 3,
[Symbol.iterator]: function *(){
for (let key in this){
yield this[key];
}
}
};