迭代器模式,内部和外部迭代器举例(设计模式与开发实践 P7)

文章目录

迭代器模式

定义:提供一种方法 顺序访问 聚合元素中的各个元素,而不需要暴露对象的内部表示

迭代器模式可以把迭代的过程从业务逻辑中分离出来

实现

我们可以使用 JavaScript 实现一个最简化的 迭代器 模型

javascript 复制代码
var each = function (arr, callback) {
  for (var i = 0; i < arr.length; i++) {
    callback(arr[i]);
  }
};

each([1, 2, 3], function (i) {
  console.log(i + 10);
});

内部迭代器

上面就是一个内部迭代器,迭代规则在内部定义,迭代器完全接手数据迭代,只需要调用一次就可以完成迭代

外部迭代器

外部迭代器必须 显式请求 迭代下一个元素,增加了调用的复杂度和灵活性

外部迭代器通过实现 Iterator 类帮助进行聚合元素的迭代

javascript 复制代码
var Iterator = function (obj) {
  var current = 0; // 内部指针
  var next = function () {
    // 遍历下一个
    current += 1;
  };
  var isDone = function () {
    // 判断是否遍历完毕
    return current >= obj.length;
  };
  var getCurrItem = function () {
    // 返回当前元素
    return obj[current];
  };
  return {
    next: next,
    isDone: isDone,
    getCurrItem: getCurrItem,
  };
};

var list = [1, 2, 3];
var iterator = Iterator(list); // 获取迭代器
while (!iterator.isDone()) {
  console.log(iterator.getCurrItem() + 10); // 输出当前值 + 10
  iterator.next(); // 迭代下一个
}

迭代 - 类数组 & 字面量对象

迭代器模式还可以迭代 arguments、字典 之类的对象

中止迭代器

通过判断 callback == true / false 来执行 break 中止迭代器也是有效的

相关推荐
神明不懂浪漫15 分钟前
【第一章】HTML(一)——HTML简述及常用标签
前端·javascript·css·html·css3
旷世奇才李先生17 分钟前
React 18\+TypeScript实战: hooks封装与组件设计模式
react.js·设计模式·typescript
白夜111722 分钟前
C++设计模式(高内聚,低耦合)
c++·设计模式
ximu_polaris25 分钟前
设计模式(C++)-结构型模式-桥接模式
c++·设计模式·桥接模式
楼田莉子26 分钟前
仿muduo库的高并发服务器——正则表达式与any类介绍及其简单模拟实现
linux·服务器·c++·学习·设计模式
英俊潇洒美少年28 分钟前
React18 Hooks 项目重构为 Vue3 组合式API的坑
前端·javascript·重构
workflower32 分钟前
机器人应用-室外区域巡逻
人工智能·设计模式·机器人·软件工程·软件构建
zs宝来了36 分钟前
Vite 构建原理:ESBuild 与模块热更新
前端·javascript·框架
geovindu3 小时前
go: Flyweight Pattern
开发语言·设计模式·golang·享元模式
英俊潇洒美少年4 小时前
Vue2/Vue3 vue-i18n完整改造流程(异步懒加载+后端接口请求)
前端·javascript·vue.js