16.迭代器 和 生成器

Symbol.iterator 迭代器 和 生成器 for of

    • [Symbol.iterator 迭代器 和 生成器 for of](#Symbol.iterator 迭代器 和 生成器 for of)
      • [1. 生成器的用法](#1. 生成器的用法)
        • [1.1. 按顺序执行,即使有异步操作,也会按顺序执行](#1.1. 按顺序执行,即使有异步操作,也会按顺序执行)
        • [1.2. ` done: true, value: undefined `说明没有东西可迭代了](#1.2. done: true, value: undefined说明没有东西可迭代了)
      • [2. 迭代器](#2. 迭代器)
        • [2.1. set和map基本用法](#2.1. set和map基本用法)
        • [2.2. 支持遍历大部分类型迭代器 arr nodeList argumetns set map 等](#2.2. 支持遍历大部分类型迭代器 arr nodeList argumetns set map 等)
        • [2.3. 迭代器的语法糖 for of](#2.3. 迭代器的语法糖 for of)
        • [2.4. for of 对象不能用,对象没有Symbol.iterator迭代器](#2.4. for of 对象不能用,对象没有Symbol.iterator迭代器)
        • [2.5. 解构底层原理也是去调用 iterator 方法, 扩展数组也是调用 iterator 方法](#2.5. 解构底层原理也是去调用 iterator 方法, 扩展数组也是调用 iterator 方法)
        • [2.6. 迭代器的原理](#2.6. 迭代器的原理)
        • [2.7. 手写对象支持for of遍历](#2.7. 手写对象支持for of遍历)

Symbol.iterator 迭代器 和 生成器 for of

1. 生成器的用法

1.1. 按顺序执行,即使有异步操作,也会按顺序执行
1.2. done: true, value: undefined说明没有东西可迭代了
javascript 复制代码
// 1. 生成器基本用法
function* gen() {
  yield Promise.resolve('小满') // 可以是同步或者是异步
  yield '大满'
  yield '超大满'
  yield '满了'
}
// let man = gen()
// console.log(man.next()) // 按顺序执行,即使有异步操作,也会按顺序执行
// console.log(man.next())
// console.log(man.next())
// console.log(man.next())
// console.log(man.next()) // done: true, value: undefined说明没有东西可迭代了

2. 迭代器

2.1. set和map基本用法
javascript 复制代码
// set map
let set: Set<number> = new Set([1, 1, 2, 2, 3, 3, 4, 4]) // 天然去重 1 2 3 4
console.log(set)
let map: Map<any, any> = new Map()
let arr = ['a', 'b', 'c']
// map和对象的区别:map的key可以是引用类型,对象只能是字符串或者symbol类型
map.set(arr, '小满')
map.set('1', 2)
// map.set('c', 3)
// console.log(map)
// console.log(map.get(arr))
2.2. 支持遍历大部分类型迭代器 arr nodeList argumetns set map 等
javascript 复制代码
// 2.1. 支持遍历大部分类型迭代器 arr nodeList argumetns set map 等
// Symbol.iterator
function arg() {
  console.log(arguments) // 维数组或者叫类数组
  // arguments.pop/push 是没有这些方法的
  // 可以使用迭代器去遍历arguments数组
}

 let list = document.querySelectorAll('div') // 类数组
 Symbol(Symbol.iterator)

 var arr = [1, 2, 3, 4]
 let iterator = arr[Symbol.iterator]()
 console.log(iterator.next())
 console.log(iterator.next())
 console.log(iterator.next())
 console.log(iterator.next())
 console.log(iterator.next())
2.3. 迭代器的语法糖 for of
javascript 复制代码
let set: Set<number> = new Set([1, 1, 2, 2, 3, 3, 4, 4]) // 天然去重 1 2 3 4
for (let i of set) {
   console.log(i) // 1 2 3 4
 }
2.4. for of 对象不能用,对象没有Symbol.iterator迭代器
javascript 复制代码
// 报错
 for (let i of {name:1}) { 
   console.log(i)
 }
2.5. 解构底层原理也是去调用 iterator 方法, 扩展数组也是调用 iterator 方法
javascript 复制代码
// 展开运算符:...arr
// 解构:[a, b, c] = [...arr]
var arr = [1, 2, 3, 4]
const [a, b, c] = [...arr]
console.log(a, b, c)
2.6. 迭代器的原理
javascript 复制代码
let set: Set<number> = new Set([1, 1, 2, 2, 3, 3, 4, 4]) 
let map: Map<any, any> = new Map()
let arr = ['a', 'b', 'c']
map.set(arr, '小满')
map.set('1', 2)
map.set('c', 3)
const each = (value: any) => {
  const It = value[Symbol.iterator]()
  let next: any = { done: false }
  while (!next.done) {
    next = It.next()
    if (!next.done) {
      console.log(next.value)
    }
  }
}

 each(map)
 each(set)
2.7. 手写对象支持for of遍历
javascript 复制代码
//  对象支持for of遍历
const obj = {
  max: 5,
  current: 0,
  [Symbol.iterator]() {
    return {
      max: this.max,
      current: this.current,
      next: () => {
        if (this.current >= this.max) {
          return { done: true, value: undefined }
        }
        return { done: false, value: this.current++ }
      }
    }
  }
}

 for (const i of obj) {
   console.log(i)
}

// 解构和扩展obj都可行
let x = [...obj]
console.log(x)
  • 2.8. 对象解构的底层调用的是for in
相关推荐
ch.ju9 小时前
Java Programming Chapter 3——Dynamic acquisition of array
java·开发语言
MXN_小南学前端9 小时前
Vue + Quill:富文本的添加、传输、展示逻辑,以及 csReplyQuill 组件封装
前端·vue.js
XS0301069 小时前
Java Web实现简易CRUD操作笔记
java·前端·笔记
TechWayfarer9 小时前
AI的幻觉谁来买单?智能体时代的数据溯源与鉴权
开发语言·python·安全·ai
Str_Null9 小时前
Python 自动线性化 HTML/MD 表格的工程实践(一个读取表格并且提供输出的工具)
开发语言·python·html
Shadow(⊙o⊙)9 小时前
qt内详解信号和槽的基本概念+实例演示
开发语言·前端·c++·qt·学习
qq_381338509 小时前
Vue3 组合式函数设计模式:从基础封装到高级复用实战
前端·vue.js·设计模式
步十人9 小时前
【CSS】基础一篇过
前端·css
回眸一笑吟离歌10 小时前
edge浏览器更新后打开局域网服务报错:ERR_ADDRESS_UNREACHABLE
前端·edge
asdzx6710 小时前
使用 C# 添加或读取 Excel 公式:完整指南
开发语言·c#·excel