⊗jsSpItIOC 67 of 294 menu

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}
日本語
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItalianoქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
当サイトでは、サイトの動作、分析、パーソナライゼーションのためにクッキーを使用しています。 データ処理はプライバシーポリシーに従って行われます。
すべて受け入れる 設定 拒否