JavaScript迭代器详解:Symbol.iterator使用教程
有志者,事竟成!如果你在学习文章,那么本文《JavaScript迭代器详解:Symbol.iterator用法解析》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~
JavaScript迭代器是统一遍历机制,核心是实现Symbol.iterator方法,该方法返回含next()的对象;Symbol.iterator是内置symbol,作为可迭代协议入口,原生对象如Array、String等默认支持,也可为自定义对象手动添加。

JavaScript 中的迭代器(Iterator)是一种统一的遍历机制,让对象能被 for...of、...扩展运算符、Array.from() 等语法识别和消费。核心在于实现 Symbol.iterator 方法——它必须返回一个符合迭代器协议的对象(即有 next() 方法,返回 { value, done } 形式的对象)。
什么是 Symbol.iterator?
Symbol.iterator 是一个内置的、唯一的 symbol 值,用作对象的“可迭代协议”的入口。当 JavaScript 引擎遇到 for...of 或其他迭代语法时,会自动查找该 symbol 对应的方法,并调用它获取迭代器。
所有原生可迭代对象(如 Array、String、Map、Set、TypedArray、arguments、NodeList)都默认实现了 [Symbol.iterator]。你也可以为自定义对象手动添加它。
手动实现一个简单迭代器
比如,让一个普通对象支持 for...of 遍历它的数值属性:
const myObj = {
a: 1,
b: 2,
c: 3,
[Symbol.iterator]() {
const keys = Object.keys(this);
let index = 0;
return {
next() {
if (index
<p>注意:因为 <code>next()</code> 是在迭代器对象内部调用的,<code>this</code> 默认不是原对象,所以要用 <code>.bind(this)</code> 或改用箭头函数/闭包保存上下文。</p>
<h3>更简洁写法:用生成器函数(推荐)</h3>
<p>手写 <code>next()</code> 容易出错。ES6 提供了生成器函数(<code>function*</code>),它天然返回符合迭代器协议的对象,写起来更直观安全:</p>
- 在对象上直接定义
[Symbol.iterator]: function*() { ... } - 函数体内用
yield逐个产出值,引擎自动处理done和状态管理
示例:
const counter = {
from: 1,
to: 3,
*[Symbol.iterator]() {
for (let i = this.from; i
<h3>判断一个对象是否可迭代</h3>
<p>检查它是否有合法的 <code>[Symbol.iterator]</code> 方法:</p>
<pre class="brush:php;toolbar:false;">function isIterable(obj) {
return obj != null && typeof obj[Symbol.iterator] === 'function';
}
isIterable([1,2]); // true
isIterable('abc'); // true
isIterable(new Set()); // true
isIterable({}); // false
注意:仅存在该属性还不够,必须是函数且调用后返回的对象有 next() 方法才算真正可迭代(但日常判断到这一步已足够)。
基本上就这些。Symbol.iterator 不是魔法,只是约定——只要按协议返回正确的迭代器对象,JS 就认得你。生成器函数是最自然、最不易出错的实现方式。
以上就是《JavaScript迭代器详解:Symbol.iterator使用教程》的详细内容,更多关于的资料请关注golang学习网公众号!
Python邮件自动化:SMTP与IMAP实战教程
- 上一篇
- Python邮件自动化:SMTP与IMAP实战教程
- 下一篇
- 哔哩哔哩官网观看教程
-
- 文章 · 前端 | 2天前 | js语法教程
- JSSet集合使用与去重技巧详解
- 350浏览 收藏
-
- 文章 · 前端 | 2天前 |
- HTML5离线缓存清除方法大全
- 462浏览 收藏
-
- 文章 · 前端 | 2天前 |
- HTML编码如何避免乱码问题
- 235浏览 收藏
-
- 文章 · 前端 | 2天前 |
- HTMLaddress标签使用方法详解
- 309浏览 收藏
-
- 文章 · 前端 | 2天前 |
- 发布订阅模式消息队列原理与实现解析
- 135浏览 收藏

