Δημιουργία επαναληπτικού αντικειμένου στο JavaScript
Ας δημιουργήσουμε ένα πραγματικά επαναληπτικό
αντικείμενο που μπορεί να διαδοθεί
μέσω του βρόχου for-of. Για να γίνει αυτό,
το αντικείμενο πρέπει να προσθέσει την αντίστοιχη
συνάρτηση στο Symbol.iterator.
Ας το υλοποιήσουμε. Ας υποθέσουμε ότι έχουμε το ακόλουθο αντικείμενο:
let obj = {
a: 1,
b: 2,
c: 3,
};
Ας προσθέσουμε μια συνάρτηση στο Symbol.iterator:
obj[Symbol.iterator] = function() {
}
Ας μετατρέψουμε αυτή τη συνάρτηση σε γεννήτρια:
obj[Symbol.iterator] = function *() {
}
Μέσα στη συνάρτησή μας, το this θα αναφέρεται
στο ίδιο το αντικείμενο:
obj[Symbol.iterator] = function *() {
console.log(this); // το ίδιο το αντικείμενο
}
Ας ξεκινήσουμε την επανάληψη του αντικειμένου στον επαναλήπτη:
obj[Symbol.iterator] = function *() {
for (let key in this) {
yield obj[key];
}
}
Όλα είναι έτοιμα, το αντικείμενο μπορεί τώρα να διαδοθεί με βρόχο
for-of:
for (let elem of obj) {
console.log(elem); // 1, 2, 3
}
Δημιουργήστε ένα αντικείμενο που μπορεί να διαδοθεί
με βρόχο for-of. Αφήστε το στοιχείο
του βρόχου να λαμβάνει ένα αντικείμενο, στο κλειδί key
του οποίου θα είναι το κλειδί του επαναληπτικού
αντικειμένου, και στο κλειδί val - η τιμή.
Παράδειγμα:
let obj = {a: 1, b: 2, c: 3};
for (let elem of obj) {
console.log(elem);
}
Θα εκτυπώσει:
{key: 'a', val: 1}
{key: 'b', val: 2}
{key: 'c', val: 3}