广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript设计模式之迭代者模式详情
  • 295
分享到

JavaScript设计模式之迭代者模式详情

2024-04-02 19:04:59 295人浏览 泡泡鱼
摘要

目录前言迭代器设计模式在生活中的运用迭代器设计模式在业务上的应用内部迭代器外部迭代器前言 迭代器设计模式是指提供一个方法去访问一个有序复杂数据,这些数据在内部有可能会用复杂的结构进行

前言

迭代器设计模式是指提供一个方法去访问一个有序复杂数据,这些数据在内部有可能会用复杂的结构进行存储,我们可以通过方法进行访问这种数据的内部的每一个元素,使用该数据无需知道是如何拿到的,只要能够进行操作即可

迭代器设计模式在生活中的运用

在生活中我们可以用收音机来表示迭代器设计模式,用户搜索到广播电台,然后从某个广播电台开始,通过向前向后的按钮进行控制遍历收听所有的广播频道,我们也可以以音乐播放器为例子,通过音乐播放器的上一首下一首按钮进行控制播放浏览的音乐,它们也可以说是提供了一个迭代器接口,进行遍历每一个频道或歌曲

迭代器设计模式在业务上的应用

迭代器设计模式在业务中分为内部迭代器和外部迭代器

内部迭代器

内部迭代器我们常见的是数组的forEach方法,内部迭代器一般都有自己的规则,我们需要按照他们特定的要求进行使用,缺点也显而易见,由于迭代规则已经约定好了,我们必须按照他们所约定的规则进行使用,所以我们如果出现某些特性需求,内部迭代器则无法满足

let arr = [{ name: "前端" }, { name: '后端' }, { name: '运维' }];
//通过forEach方法对数据进行迭代,forEach方法接收一个回调函数,该回调函数中接收三个参数,第一个是当前的循环的每一项,第二个是当前索引,第三个是当前迭代的总数组,这就是内部迭代器的规则
        arr.forEach(function(res,index,arr){
            console.log(res.name);
        })

外部迭代器

外部迭代器必须显式的进行迭代,增加了调用的复杂度同时也相对的增加了迭代器的灵活性,可以手动的进行操控迭代过程以及迭代顺序,将迭代相关的数据暴露出来进行处理后返回

我们来手写一个外部迭代器方法,里面拥有一个标记index参数,用于获取下一次数据,拥有一个next方法,该方法会进行对index标记进行自增后然后返回一个对象,对象中拥有俩个参数value是代表着当前标记下的数据,done是当前数据是否还能继续往下调用next方法的标记,最后在返回一个全新的处理过后的数据,通过调用next方法可以看到当前的项的数据

const arr = [{name:"javascript"}, {name:"Go"},{name:"node.js"}];
        function Iterator(data) {
            let index = 0;
            function next(){
                index++;
                return {
                    value: data[index],
                    done: data.length == index
                }
            };
            return {
                next
            }
        }

使用外部迭代器:

      const iter = Iterator(arr);
        console.log(iter.next());
        console.log(iter.next());
        console.log(iter.next());

迭代器设计模式能够可以让我们更方便的且有规矩的进行访问复合数据的每一项,也可以通过迭代器进行完成一些流线式操作

到此这篇关于JavaScript设计模式之迭代者模式详情的文章就介绍到这了,更多相关JavaScript迭代模式内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript设计模式之迭代者模式详情

本文链接: https://www.lsjlt.com/news/152373.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript设计模式之迭代者模式详情
    目录前言迭代器设计模式在生活中的运用迭代器设计模式在业务上的应用内部迭代器外部迭代器前言 迭代器设计模式是指提供一个方法去访问一个有序复杂数据,这些数据在内部有可能会用复杂的结构进行...
    99+
    2022-11-13
  • javascript设计模式之迭代器模式
    目录迭代器模式介绍示例迭代器模式UML类图迭代器模式原生代码演示迭代器模式的场景ES6 Iterator示例总结迭代器模式介绍 顺序访问一个集合 顺序:如数组、类数组称为顺序,而非对...
    99+
    2022-11-12
  • JavaScript设计模式之原型模式详情
    目录前言案例回顾原型的拓展前言 设计模式呢最多的可能是用到类,我们去通过类来封装一些实用的方法,通过设计模式去实现各个方法之间的解耦等,由于JS中的继承是用原型链继承的,所以原型模式...
    99+
    2022-11-13
  • JavaScript设计模式之中介者模式详解
    目录中介者模式现实中的中介者中介者模式的例子泡泡堂游戏为游戏增加队伍玩家增多带来的困扰用中介者模式改造泡泡堂游戏小结中介者模式 在我们生活的世界中,每个人每个物体之间都会产生一些错综...
    99+
    2022-11-13
    JavaScript 设计模式 JavaScript 中介者模式
  • Java设计模式之java迭代器模式详解
    目录前言介绍角色迭代器模式中的工厂模式学院遍历的案例分析解决方案基本介绍原理类图上面案例的类图案例实现代码案例总结应用实例Java集合中的迭代器模式角色说明Mybatis中的迭代器模...
    99+
    2022-11-12
  • Java设计模式之迭代器模式
    本文介绍设计模式中的迭代器模式,首先通俗的解释迭代器模式的基本概念和对应的四个角色,并根据四个角色举一个典型的实例,为了加强知识的连贯性,我们以Jdk源码集合中使用迭代器模式的应用进...
    99+
    2022-11-13
  • javascript设计模式之订阅者模式
    目录一. 初识代理模式二. 代理模式的实现思想三. 代理模式分类四. 虚拟代理模式的实际运用五. 代理的使用意义及要求六. 总结一. 初识代理模式 代理模式是为一个对象提供一个代用品...
    99+
    2022-11-12
  • javascript设计模式之迭代器模式的示例分析
    这篇文章主要介绍了javascript设计模式之迭代器模式的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。迭代器模式分为内部迭代器和...
    99+
    2022-10-19
  • javascript设计模式之代理模式
    目录一. 初识代理模式二. 代理模式的实现思想三. 代理模式分类四. 虚拟代理模式的实际运用五. 代理的使用意义及要求六. 总结一. 初识代理模式 代理模式是为一个对象提供一个代用品...
    99+
    2022-11-12
  • C#设计模式实现之迭代器模式
    目录前言:一、餐馆合并菜单 二、改进菜单实现 三、迭代器模式 总结前言: 迭代器模式平时用的不多,因为不管C#还是Java都已经帮我封装了,但是你是否知道平时经常在用的东西本质是怎么...
    99+
    2022-11-12
  • PHP设计模式之迭代器模式浅析
    目录迭代器模式PHP中的迭代器模式迭代器模式 迭代器模式(Iterator Pattern)是一种常用的设计模式,用于遍历集合中的元素,不暴露集合的内部结构。迭代器模式将集合和遍历分...
    99+
    2023-05-14
    PHP迭代器模式 PHP 设计模式 迭代器模式
  • Java设计模式之装饰者模式详解
    目录具体代码:Person:Student:Doctor:DecoratePerson:ShoeDecorate:DressDecorate:总结 装饰器模式(Decorator P...
    99+
    2022-11-12
  • PHP设计模式之迭代器模式的使用
    目录Gof类图及解释实例一说到这个模式,就不得不提循环语句。在《大话设计模式》中,作者说道这个模式现在的学习意义更大于实际意义,这是为什么呢?当然就是被foreach这货给整得。任何...
    99+
    2022-11-12
  • 设计模式之建造者模式
    文章目录 盖房项目需求传统方式解决盖房需求传统方式的问题分析建造者模式概述是建造者模式的四个角色建造者模式原理类图建造者模式的注意事项和细节 盖房项目需求 需要建房子:这一过程为打桩、砌墙、封顶房子有各种各样的,比如普通房,高楼...
    99+
    2023-08-30
    设计模式
  • javascript设计模式之装饰者模式怎么用
    这篇文章主要为大家展示了“javascript设计模式之装饰者模式怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“javascript设计模式之装饰者模式怎...
    99+
    2022-10-19
  • Java设计模式中的迭代器模式详解
    目录一 定义二 UML类图三 代码实例四 迭代器模式的优缺点4.1 优点4.2 缺点五 使用场景六 JDK迭代器的运用一 定义 提供一个对象来顺序访问聚合对象中的一系列数据,而不暴露...
    99+
    2023-02-08
    Java迭代器模式 Java设计模式
  • Java设计模式之java中介者模式详解
    目录引言介绍角色数据库同步数据案例不使用中介者模式的数据同步方案,各数据源维护各自的同步作业其实这样已经实现了我们的需求,但是存在一些问题中介者模式来重构,将数据同步的功能迁移到中介...
    99+
    2022-11-12
  • Java设计模式之java观察者模式详解
    目录引言介绍角色原理类图微信订阅号的案例总结优点缺点适用场景观察者模式的典型应用JDK 提供的观察者接口Guava EventBus 中的观察者模式Spring Applicatio...
    99+
    2022-11-12
  • Java设计模式之java访问者模式详解
    目录介绍定义及使用场景UML类图角色财务案例个人心得体会静态分派以及动态分派静态分派动态分派访问者模式中的伪动态双分派 对访问者模式的一些思考总结优点缺点适用性参考文章总结介绍 ...
    99+
    2022-11-12
  • Java设计模式之java装饰者模式详解
    目录介绍角色示例代码星巴克咖啡的例子方案一方案二 :将调料内置到Drink类中方案三:装饰者模式代码演示装饰者模式的简化透明性的要求半透明的装饰模式装饰模式的优点装饰模式的缺点装饰模...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作