前端 JS 经典:迭代器

在 JavaScript 中,迭代器是一个对象,它定义了一个序列,并在终止时可能返回一个返回值。更具体地说,迭代器是通过使用**next()**方法实现迭代器协议(Iterator protocol)的任何对象,该方法返回具有两个属性的对象:

**value:**表示序列中的下一个值。

**done:**它是一个布尔类型的值,如果已经迭代到序列中的最后一个值,则为 true。

迭代器会保存一个内部指针,用来指向当前集合中值的位置。每调用一次 next()方法,都会返回下一个可用的值。如果在最后一个值返回后再调用 next()方法,那么返回的对象中属性 done 的值为 true,属性 value 则包含迭代器最终返回的值(如果没有相关数据则返回 undefined)。

JavaScript 中有一些内置的可迭代对象,如数组、字符串、集合(Set)、映射(Map)等,它们都具有默认的迭代器。例如,可以使用 for...of 循环来遍历这些可迭代对象。

以下是一个简单的迭代器示例:

javascript 复制代码
function createIterator(items) {

  let i = 0;

  return {

    next: function () {

      let done = i >= items.length;

      let value = !done ? items[i++] : undefined;

      return { done: done, value: value };

    },

  };

}

var iterator = createIterator([1, 2, 3]);

console.log(iterator.next()); // { done: false, value: 1 }

console.log(iterator.next()); // { done: false, value: 2 }

console.log(iterator.next()); // { done: false, value: 3 }

console.log(iterator.next()); // { done: true, value: undefined }

在上述示例中,createIterator函数返回了一个自定义的迭代器对象,通过调用 next 方法可以逐步获取数组中的元素。

并非所有对象都是可迭代的,普通对象默认不可迭代。但可以通过为对象添加[Symbol.iterator]属性并使其返回一个符合迭代器协议的对象,将自定义对象变为可迭代对象。

可迭代对象具有 Symbol.iterator 属性,通过指定的函数可以返回一个作用于附属对象的迭代器。迭代器的使用可以让代码更简洁、更灵活地处理数据序列,并且能够更好地处理一些复杂的数据结构和迭代逻辑。它提供了一种统一的方式来遍历不同类型的集合,而无需关心集合内部的具体实现细节。

相关推荐
Jet45052 分钟前
第100+42步 ChatGPT学习:R语言实现阈值调整
开发语言·学习·chatgpt·r语言
虾球xz2 分钟前
CppCon 2016 学习:fixed_point Library
开发语言·c++·学习
希希不嘻嘻~傻希希10 分钟前
CSS 字体与文本样式笔记
开发语言·前端·javascript·css·ecmascript
石小石Orz31 分钟前
分享10个吊炸天的油猴脚本,2025最新!
前端
爷_1 小时前
Nest.js 最佳实践:异步上下文(Context)实现自动填充
前端·javascript·后端
寄思~1 小时前
Python学习笔记:错误和异常处理
开发语言·笔记·python·学习
clmm1231 小时前
Java动态生成Nginx服务配置
java·开发语言·nginx
爱上妖精的尾巴1 小时前
3-19 WPS JS宏调用工作表函数(JS 宏与工作表函数双剑合壁)学习笔记
服务器·前端·javascript·wps·js宏·jsa
lzb_kkk2 小时前
【MFC】编辑框、下拉框、列表控件
c语言·开发语言·c++·mfc·1024程序员节
草履虫建模2 小时前
Web开发全栈流程 - Spring boot +Vue 前后端分离
java·前端·vue.js·spring boot·阿里云·elementui·mybatis