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
相关推荐
qq_422152576 小时前
Word 文件太大怎么压缩?2026 年文档瘦身方案对比
开发语言·c#·word
charliedev6 小时前
Jedi:Python 自动补全与静态分析的实用工具
开发语言·python·其他
slongzhang_6 小时前
jquery 修复怪异模式html未声明“<!DOCTYPE html>”
前端·html·jquery
宋拾壹6 小时前
fastadmin列表中查看列表,并且添加增加相应的数据
javascript·php·fastadmin
ji198594436 小时前
MATLAB 求散点曲线斜率
开发语言·算法·matlab
kaikaile19956 小时前
MATLAB 实现:Koch & Zhao 图像水印算法(DCT域)
开发语言·算法·matlab
love_muming6 小时前
链表每日一练
java·开发语言·数据结构·链表·idea·每日一练
weixin_446260856 小时前
LLM智能体在社交模拟中的决策行为分析:有限状态与LLM-based策略对比研究
开发语言·php
牛肉在哪里6 小时前
ros2 从零开始28 监听广播C++
开发语言·c++·算法·机器人
techdashen7 小时前
Cargo 1.94 开发周期全解析
开发语言·后端·rust