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}