Skip to content

Commit

Permalink
Merge pull request #107 from GuoXiCheng/dev-c
Browse files Browse the repository at this point in the history
update iterator md
  • Loading branch information
GuoXiCheng authored Jul 30, 2024
2 parents 7a6d1cc + 84fe44b commit 797c0e5
Show file tree
Hide file tree
Showing 6 changed files with 60 additions and 91 deletions.
18 changes: 13 additions & 5 deletions src/.vitepress/sidebars/ecma-script.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -123,14 +123,22 @@
items:
- text: 什么是迭代器
link: /javascript/ecma-script/iterators-and-generators/iterator#什么是迭代器
- text: 迭代方式的演变
link: /javascript/ecma-script/iterators-and-generators/iterator#迭代方式的演变
- text: 迭代器模式
link: /javascript/ecma-script/iterators-and-generators/iterator-pattern
items:
- text: 可迭代协议
link: /javascript/ecma-script/iterators-and-generators/iterator#可迭代协议
link: /javascript/ecma-script/iterators-and-generators/iterator-pattern#可迭代协议
- text: 迭代器协议
link: /javascript/ecma-script/iterators-and-generators/iterator#迭代器协议
- text: 提前终止迭代
link: /javascript/ecma-script/iterators-and-generators/iterator#提前终止迭代
link: /javascript/ecma-script/iterators-and-generators/iterator-pattern#迭代器协议
- text: 自定义迭代器
link: /javascript/ecma-script/iterators-and-generators/custom-iterator
link: /javascript/ecma-script/iterators-and-generators/iterator-custom
items:
- text: 实现迭代器接口
link: /javascript/ecma-script/iterators-and-generators/iterator-custom#实现迭代器接口
- text: 提前终止迭代
link: /javascript/ecma-script/iterators-and-generators/iterator-custom#提前终止迭代
- text: 生成器
link: /javascript/ecma-script/iterators-and-generators/generator
- text: JSON
Expand Down
6 changes: 3 additions & 3 deletions src/backend/nodejs/file-system/stream-operation.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,12 @@

## 读取流

<<< @/../projects/javascript-sandbox/src/file-system/stream-read.ts
<<< @/../projects/javascript-sandbox/src/file-system/stream-read.ts#read

## 写入流

<<< @/../projects/javascript-sandbox/src/file-system/stream-write.ts
<<< @/../projects/javascript-sandbox/src/file-system/stream-write.ts#write

## 管道流

<<< @/../projects/javascript-sandbox/src/file-system/stream-pipe.ts
<<< @/../projects/javascript-sandbox/src/file-system/stream-pipe.ts#pipe

This file was deleted.

Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# 自定义迭代器

## 实现迭代器接口

任何实现了 Iterator 接口的对象都可以作为迭代器使用。

<<<@/../projects/javascript-sandbox/src/iterators-and-generators/iterator-custom.ts#custom-iterator

## 提前终止迭代

可选的 `return()` 方法定义了在迭代器被提前关闭时执行的操作。

<<<@/../projects/javascript-sandbox/src/iterators-and-generators/iterator-custom.ts#early-termination
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# 迭代器模式

ES6 引入的迭代器模式,`Iterable` 接口定义了对象是否可迭代,`Iterator` 接口定义了对象如何迭代。

## 可迭代协议

任何实现了 `[Symbol.iterator]()` 方法的对象都被认为是可迭代的,这个方法必须返回一个 `Iterator` 对象。

ES 内置的可迭代对象有:数组、Map、Set、字符串、arguments 对象、NodeList 对象。

<<< @/../projects/javascript-sandbox/src/iterators-and-generators/iterator.ts#iterable-protocol

可迭代对象可以使用 `for...of` 循环,`...` 扩展运算符,解构赋值进行迭代。

<<< @/../projects/javascript-sandbox/src/iterators-and-generators/iterator.ts#iterator-method

## 迭代器协议

`Iterator` 接口定义了一个 `next()` 方法,该方法返回一个包含 `done``value` 属性的对象,`done` 是一个布尔值,指示是否还有更多值可以迭代,`value` 包含当前的值。

`done = true` 时,`value = undefined`时,表示迭代结束。

<<< @/../projects/javascript-sandbox/src/iterators-and-generators/iterator.ts#iterator-protocol
64 changes: 8 additions & 56 deletions src/javascript/ecma-script/iterators-and-generators/iterator.md
Original file line number Diff line number Diff line change
@@ -1,69 +1,21 @@
# 迭代器

## 什么是迭代器

::: details 什么是迭代
迭代就是在一个有序集合上顺序访问元素的过程。
:::

迭代器提供了一种方法,使得任何支持可迭代协议的对象都能在不暴露内部结构的情况下访问其中的元素。

::: details 迭代方式的演变

JavaScript 中的 for 循环提供了一种基础的迭代方式,但这要求开发者明确知道如何与数据结构交互,例如通过索引访问数组元素。这种方法依赖于数据结构的内部实现细节,并且不适用于所有类型的数据结构。

ES5 新增的`forEach`方法允许开发者无需直接管理索引即可遍历数组,这项功能向通用迭代需求迈进了一步,但是`forEach`方法不能在迭代过程中提前终止(除非抛出异常),因此仍然不够理想。

为了解决这些限制,ES6 引入了迭代器模式,这是一种使开发者无需预先知道集合的内部结构即可遍历集合的方法。

:::

## 可迭代协议

可迭代协议允许对象表明自己支持迭代。

要遵循此协议,对象必须暴露一个特殊属性`Symbol.iterator`,该属性是一个函数,调用该函数会返回一个迭代器对象,迭代器对象必须遵循迭代器协议。

::: details 内置迭代

内置可迭代对象:数组、Map、Set、字符串、arguments 对象、NodeList 对象、TypedArray 对象、Generator 对象。

内置迭代方法:for...of 循环、...扩展运算符、解构赋值
迭代就是在一个有序集合上顺序访问元素的过程。

:::

## 迭代器协议
## 什么是迭代器

迭代器代表对其关联可迭代对象的一次性有序遍历
迭代器提供了一种方法,使得任何支持可迭代协议的对象都能在不暴露内部结构的情况下访问其中的元素

迭代器的核心方法`next()`用于在遍历过程中逐一访问数据。每次调用`next()`成功时,都会返回一个包含`done``value`属性的对象。`done`是一个布尔值,指示是否还有更多值可以迭代;`value`包含当前的值,在`done=true``value=undefined`
## 迭代方式的演变

## 提前终止迭代
`Javascript` 中的 `for` 循环提供了一种基础的迭代方式,但这要求开发中明确知道如何与数据结构交互(例如:通过索引访问数组元素)。

迭代器可以可选地实现一个 return 方法,该方法定义了在迭代器被提前关闭时执行的操作,它应当返回一个有效的迭代器结果对象,通常是`{ done: true }`。如果迭代器没有关闭,它可以从上次停止的地方继续迭代
这种基础迭代方式依赖于数据结构内部的实现细节,并不适用于所有类型的数据结构

```js
class Counter {
constructor(limit) {
this.limit = limit;
}
`ES5` 新增的 `forEach` 方法允许开发者在无需管理索引的情况下迭代数组,这项功能向通用迭代迈进了一步,但 `forEach` 方法不能在迭代过程中提前终止(除非抛出异常),因此仍然不够理想。

[Symbol.iterator]() {
let count = 1,
limit = this.limit;
return {
next() {
if (count <= limit) {
return { done: false, value: count++ };
} else {
return { done: true };
}
},
return() {
console.log("Exiting early");
return { done: true };
},
};
}
}
```
`ES6` 引入了迭代器模式解决了这些限制,这是一种使开发者无需预先知道集合的内部结构即可遍历集合的方法。

0 comments on commit 797c0e5

Please sign in to comment.