IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Generator生成器 和 Iterator迭代器 -> 正文阅读

[JavaScript知识库]Generator生成器 和 Iterator迭代器

js中的迭代器(Iterator) - 掘金?

generator - 廖雪峰的官方网站

Iterator

Iterator是一种机制,也可以说是一种接口,它为不同的数据结构提供了统一的访问机制。任何数据结构只要配置了 Iterator 接口,就可以完成遍历操作

for...of循环的背后调用的正是iteration,数组对象上有iteration属性,数组是一个可迭代对象,因此数组可以被for...of遍历

一个数据结构只要部署了Symbol.iterator属性,就被视为具有 iterator 接口,这个接口就可以被for...of循环消费,从而遍历它的成员。

? ? ? ? ? ? // 迭代器 iterator : 含有next方法,返回 {value:'',done:false}

? ? ? ? ? ? // 可用 for of 进行迭代

? ? ? ? ? ? // 所有集合类型,Array,Set,Map,String 都可以迭代

? ? ? ? ? ? // Generator 生成器 ,内部 处理完一个 yield就暂停,所以可以处理异步

? ? ? ? ? ? // 生成器——>迭代对象

? ? ? ? ? ? function* getdata(){

? ? ? ? ? ? ? ?

? ? ? ? ? ? ? ? yield 1

? ? ? ? ? ? ? ? yield 2

? ? ? ? ? ? }

? ? ? ? ? ? y=getdata() // 这是一个迭代器

? ? ? ? ? ? y.next() ?// {value:1,done:false}

? ? ? ? ? ? y.next() ?// {value:2,done:true}

? ? ? ? ? ? // 生成器,可以记住执行状态,利用这一点,写一个generator就可以实现需要用面向对象才能实现的功能,替代闭包的实现方式。

? ? ? ? ? ? // 另一个巨大的好处,就是把异步回调代码变成“同步”代码

可以把原来不是可迭代的数据类型变成可迭代的,这样就能支持for...of循环

            let obj={
                
                data:[{a:'1111'},{b:'2222'}],
                [Symbol.iterator]:function(){
                   let _this=this
                   let index=0
                    return {
                        next:()=>{
                           if(index<_this.data.length){
                               const res = { value : _this.data[index] , done:false }
                               index++
                               return res
                           }else{
                               const res = { value : undefined , done:true } 
                               index++
                               return res
                           }
                        }
                    }
                }
            }

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-06 12:53:24  更:2022-03-06 12:55:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 8:41:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码