Get to know MDN better
此頁面由社群從英文翻譯而來。了解更多並加入 MDN Web Docs 社群。
為 ECMAScript 2015 中的一些補充內容,並非新的內建物件或語法,而是協議。這些協議可被任何遵守特定協定的物件所實作。
可迭代(iterable)協議允許 JavaScript 物件定義或客制他們的迭代行為,例如哪些值可在 for..of 語法結構中被迭代出來。部分內建型別為擁有預設迭代行為的可迭代內建物件,如 Array 或 Map,而其他型別(如 Object)則否。
為了成為可迭代的,一個物件必須實作 [Symbol.iterator]() 方法,意思是這個物件(或其原型鏈中的其中一個原型物件)必須擁有一個鍵(key)值為 [Symbol.iterator](即 Symbol.iterator 常數)的屬性:
[Symbol.iterator]回傳符合迭代器協議之物件的無引數函式。
每當物件需要被迭代時(比如在一個開始的 for..of 迴圈中),物件的 [Symbol.iterator]() 方法會被以不傳入引數的方式呼叫,並會使用其回傳的迭代器來獲得被迭代出來的值。
迭代器(iterator)協議定義了一個標準方式來產出一連串(有限或無限)的值,並且可能於所有值都被產出後回傳一個值。
當物件以下列語義實作了 next() 方法即為一個迭代器:
| next |
回傳一個至少擁有以下兩個屬性之物件的無引數函式:
next 方法必須總是回傳一個包含符合 done 及 value 屬性的物件。假如回傳了一個非物件值(如 false 或 undefined),則將會拋出一個 TypeError 錯誤。 |
備註:我們無法反射性的一眼看出一個特定的物件是否實作了迭代器協議,然而要建立一個同時滿足迭代器及可迭代協議的物件卻是相當容易(如下例所示)。範例的做法允許一個迭代器被各個預期其可迭代行為的語法所消費。因此很少有需要實作迭代器協議而沒有實作可迭代協議的情況。
String 為一個可迭代內建物件(built-in iterable object)的範例:
String 的預設迭代器會回傳字串中的一個一個字元:
部分內建語法結構(built-in constructs),如 spread syntax,其內部也使用了相同的迭代協議:
我們可以藉由提供我們自己的 [Symbol.iterator]() 來重新定義迭代行為:
請注意,重新定義 [Symbol.iterator]() 會影響使用迭代協議之內建語法結構的行為:
String、Array、TypedArray、Map 以及 Set 全都是可迭代內建物件,因為他們每一個的原型物件皆實作了 [Symbol.iterator]() 方法。
我們可以建立自己的可迭代物件,像是:
有許多 APIs 接受可迭代物件,如:Map([iterable])、WeakMap([iterable])、Set([iterable]) 及 WeakSet([iterable]):
另外可參考 Promise.all(iterable)、Promise.race(iterable) 以及 Array.from()。
部分陳述式(statements)及運算式(expressions)為預期用於可迭代物件,例如 for-of 迴圈、spread syntax、yield*,及解構:
假如可迭件物件的 [Symbol.iterator]() 方法不是回傳一個迭代器物件,即是非良好的(non-well-formed)可迭代物件。如以下方式使用可能會導致執行時期異常或錯誤行為:
生成器物件同時為迭代器及可迭代物件:
This page was last modified on 2025年7月16日 by MDN contributors.
Your blueprint for a better internet.
Visit Mozilla Corporation’s not-for-profit parent, the Mozilla Foundation.
Portions of this content are ©1998–2026 by individual mozilla.org contributors. Content available under a Creative Commons license.