热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[译]调试RxJS第1部分:工具篇

原文链接:blog.angularindepth.comdebugging-r…本文为RxJS中文社区翻译文章,如需转载,请注明出处,谢谢



原文链接: blog.angularindepth.com/debugging-r…
本文为 RxJS 中文社区 翻译文章,如需转载,请注明出处,谢谢合作!
如果你也想和我们一起,翻译更多优质的 RxJS 文章以奉献给大家,请点击【这里】



我是一位 RxJS 信徒,在我所有活跃的项目中都在使用它。用了它之后,我发现很多乏味的事现在都变得很简单。然而,有一件事却没有任何好转,那就是调试。


由于 RxJS 的可组合性与有时是异步的本质使得调试变成了一种挑战:没有太多的状态可以观察,而且调用堆栈基本也没什么帮助。我之前的做法是在整个代码库中穿插大量的 do 操作符和日志来检查流经组合 observables 的值。由于以下几点原因,我对这种方法并不满意:


  • 我总是在不断地添加日志,调试的同时还要更改代码
  • 调试完成后,对于日志,我要么一条条的进行手动删除,要么选择忍受
  • 匆忙之中将 do 操作符随意放置在一个组合 observable 中间时,应该避免有条件的日志输出的太恐怖
  • 即使是专门的日志操作符,其体验也不理想

最近,我花费了一些时间开发了一个 RxJS 的调试工具。它有如下几个功能,而且我觉得是这个工具必须要具备的:


  • 它应该尽可能地不唐突
  • 它应该不需要靠不断修改代码来进行调试
  • 特别是,它应该不需要解决问题后靠手动删除或注释掉调试代码
  • 它应该支持可以轻松启用和禁用的日志
  • 它应该支持捕获可以随时间进行比较的快照
  • 它应该提供一些与浏览器控制台的集成,用于打开/关闭调试功能和检查状态,等等

还有一些功能,如果能有就更好了:


  • 它应该支持暂停 observables
  • 它应该支持修改 observables 或 observables 发出的值
  • 它应该支持除控制台之外的日志机制
  • 它应该是可扩展的
  • 它应该采取一些方法来捕获可视化订阅依赖所需的数据

综合考虑这些功能后,我开发了 rxjs-spy


核心概念


rxjs-spy 引入了 tag 操作符,它将一个字符串标签和一个 observable 关联起来。这个操作符并没有以任何方式来改变 observable 的行为和值。


tag 操作符可以单独使用: import "rxjs-spy/add/operator/tag" 。这样的话,rxjs-spy 的其他方法会在生成版本中被忽略,所以唯一的开销就是字符串的使用 (导入)。


大多数工具方法都接受匹配器 ( matchers ),以确定它们即将应用哪些标记过的 observables 。匹配器可以是简单的字符串、正则表达式或传递标签本身的函数谓词 ( predicates )。


当通过调用工具的 spy 方法配置后,它会在 Observable.prototype.subscribe 上打补丁,这样它就能够侦察到所有的订阅、通知和取消订阅。当然,只有被订阅的 observables 才能通过 spy 进行侦察。


rxjs-spy 公开了一个模块 API 用于在代码中调用,还公开了一个控制台 API 供用户在浏览器的控制台中进行交互。大多数时候,我都是在应用的启动代码中早早地调用模块 API 的 spy 方法,然后使用控制台 API 来执行剩下的调试工作。


控制台 API 功能


调试时,我通常使用浏览器的控制台来检查和操纵标记过的 observables 。控制台 API 还是通过示例来解释比较容易,下面的代码示例展示了如何与 observables 配合使用:


import { Observable } from "rxjs/Observable";
import { spy } from "rxjs-spy";
import "rxjs/add/observable/interval";
import "rxjs/add/operator/map";
import "rxjs/add/operator/mapTo";
import "rxjs-spy/add/operator/tag";
spy();
const interval = new Observable
.interval(2000)
.tag("interval");
const people = interval
.map((value) => {
const names = ["alice", "bob"];
return names[value % names.length];
})
.tag("people")
.subscribe();

rxjs-spy 的控制台 API 是通过全局变量 rxSpy 公开的。


调用 rxSpy.show() 会显示所有标记过的 observables 列表,并表明它们的状态 (未完成、已完成或报错)、订阅者的数量以及最新发出的值 (如果有值发出的话)。控制台输出是像这样的:







要显示某个特定的标记 observable,需要将标签名或正则表达式传给 show:







通过调用 rxSpy.log 可以启用某个标记 observable 的日志:







调用 log 时不带任何参数会启用所有标记 observables 的日志。


模块 API 的大部分方法会返回一个拆解函数,它用来解除方法的调用。在控制台中管理这些太麻烦了,所以还有另外一种选择。


调用 rxSpy.undo() 会显示所有调用过的方法的列表:







使用方法调用相关联的数字来调用 rxSpy.undo 会直接调用调用方法的拆解函数。例如,调用 rxSpy.undo(3) 会看到 interval observable 的日志停止输出:







有时候,当调试的同时修改 observable 或它的值是很有用的。控制台 API 包含 let 方法,它的作用同 RxJS 中的 let 操作符十分相似。它的实现方式是这样的:调用 let 方法会影响到标记 observable 的当前订阅者和将来的订阅者。例如,下图中的调用会看到 people observable 发出 mallory,而不是 alicebob:







log 方法一样,let 方法的调用也可以取消:







对我来说,调试时能够暂停 observable 的功能几乎是不可或缺的。调用 rxSpy.pause 会暂停标记 observable 并返回一个用于控制和检查 observable 通知的 deck 对象:







调用 deck 的 log 方法会显示 observable 是否暂停和暂停期间的所有通知 (通知是使用 materialize 操作符获取的 RxJS 的 Notification 实例)。







调用 deck 的 setp 方法会发出一条通知:







调用 resume 方法会发出所有暂停期间的通知并恢复 observable:







调用 pause 会看到 observable 再次回到暂停状态:







很容易会忘记将返回的 deck 赋值给了哪个变量,所以控制台 API 还提供了 deck 方法,它的行为类似于 undo 方法。调用它会显示所有 pause 调用的列表:







使用 pause 调用相关联的数字来调用 deck 方法并会返回相关联的 deck 对象:







就像 loglet 调用一样,pause 调用也可以取消,并且取消 pause 调用会恢复标记的 observable:







希望上面的示例会让你对 rxjs-spy 以及它的控制台 API 有一个大致的了解。「 调试 RxJS 」系统的后续部分会专注于 rxjs-spy 的具体功能,以及如何使用它来解决实际的调试问题。


对于我而言,rxjs-spy 确实可以使调试 RxJS 变得有趣起来。


更多信息


rxjs-spy 的源码托管在 GitHub 上,这里有一个可以操作控制台 API 的在线示例。


还可以通过 NPM 来安装包。


本系列的下篇文章 —「 调试 RxJS 第2部分:日志篇 」




推荐阅读
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 本文介绍了Linux系统中正则表达式的基础知识,包括正则表达式的简介、字符分类、普通字符和元字符的区别,以及在学习过程中需要注意的事项。同时提醒读者要注意正则表达式与通配符的区别,并给出了使用正则表达式时的一些建议。本文适合初学者了解Linux系统中的正则表达式,并提供了学习的参考资料。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • 20211101CleverTap参与度和分析工具功能平台学习/实践
    1.应用场景主要用于学习CleverTap的使用,该平台主要用于客户保留与参与平台.为客户提供价值.这里接触到的原因,是目前公司用到该平台的服务~2.学习操作 ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 本文介绍了如何使用python从列表中删除所有的零,并将结果以列表形式输出,同时提供了示例格式。 ... [详细]
author-avatar
大牛
大水牛
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有