前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Rxjs 里 subscribeToArray 工具函数的详细分析

Rxjs 里 subscribeToArray 工具函数的详细分析

作者头像
Jerry Wang
发布2021-06-10 15:35:52
3560
发布2021-06-10 15:35:52
举报

subscribeToArray 函数体的逻辑:它的实质是一个函数:

该函数接收一个 array 作为输入参数,遍历这个 array,将其每个元素,作为另一个匿名函数执行的一部分。该匿名函数体内,将 array 的元素作为 subscriber 订阅函数的输入:

对上述代码进行一点增强:

代码语言:javascript
复制
<html>
<script>
const subscribeToArray = (array) => (subscriber) => {
    for (let i = 0, len = array.length; i < len && !subscriber.closed; i++) {
        subscriber.next(array[i]);
    }
    subscriber.complete();
};

const aInput = [1,2,3,4];

const newFunction = subscribeToArray(aInput);

debugger;
</script>
</html>

在调试器里查看 newFunction,发现第12行代码调用 subscribeToArray,输入的 aInput,已经维护到新函数的Closure(闭包)里了:

这个 newFunction 应该怎么消费呢?

代码语言:javascript
复制
<html>
<script>
const subscribeToArray = (array) => (subscriber) => {
    for (let i = 0, len = array.length; i < len && !subscriber.closed; i++) {
        subscriber.next(array[i]);
    }
    subscriber.complete();
};

const aInput = [1,2,3,4];

const newFunction = subscribeToArray(aInput);

const subscriber = {
	closed: false
};

subscriber.next = (data) => console.log("next: " + data);
subscriber.complete = () => console.log("completed!");
debugger;

newFunction(subscriber);
</script>
</html>

输出:

回到 fromArray.js 的 subscribeToArray,也就不难理解其逻辑了:

直到应用程序代码调用 Observable 的 subscribe 方法时,才会变量 input 数组,用 subscribe 的 next 方法依次处理 input 数组的元素。在 CombineLatest Operator 的例子里,input 元素就是 Observable 对象的组合。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-06-06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档