首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    说清 Observable

    在 JavaScript 开发中,我们一般用事件模型 来替代传统的发布—订阅模式。 现实中的发布-订阅模式 不论是在程序世界里还是现实生活中,发布—订阅模式的应用都非常之广泛。...现实中的发布-订阅模式 在刚刚的例子中,发送短信通知就是一个典型的发布—订阅模式,小明、小红等购买者都是 订阅者,他们订阅了房子开售的消息。...可以发现,在这个例子中使用发布—订阅模式有着显而易见的优点。 购房者不用再天天给售楼处打电话咨询开售时间,在合适的时间点,售楼处作为发布者 会通知这些消息订阅者。...在异步编程中 使用发布—订阅模式,我们就无需过多关注对象在异步运行期间的内部状态,而只需要订阅感兴 趣的事件发生点。...迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即 使不关心对象的内部构造,也可以按顺序访问其中的每个元素。

    52620

    谈谈FRP和Observable(二)

    node的stream是和unix哲学紧密契合的概念,非常好用,很简单,容易使用,这是它的优点;但它局限在IO,通用性不如Observable,而且提供的操作也仅仅限于pipe等最基础的操作,虽然有 event-stream...你可以很容易把C#的例子转换成javascript的例子,你也可以在前端使用javascript处理Observable,在后端使用java处理Observable,这便是 ?...让我来解释一下核心代码: render在Observable addTodo$ 产生新数据的时候重绘整个list(这里如果使用virtual dom,会大大提高performance) addTodo$...案例三:data collection 在服务器端,只要你勤于思考,也能发现Observable的广阔的用武之地。比如我要做一个服务,定期从若干台服务器中获取(pull)资源使用使用信息。...do 在Observable里,遇到上游的Observable传过来的内容,不做任何处理,向下游传递,同时,在函数体内做相应的副作用的处理。

    99350

    RxSwift介绍(二)——Observable

    打印结果 在Observable对象中,可以根据三种事件创建自定义的可观察序列。在可观察序列中,分为有限观察序列与无限观察序列。...Observable创建 以下列出Observable各种创建的方法,以及对应不同的使用场景 just方法 该方法通过传入一个默认值来初始化 let createJustObservable...订阅与销毁 与 RAC 的订阅信号方法非常类似,使用过程中是需要在需要订阅 Observable 的地方调用 subscribe 方法即可。...在RxSwift中每一个订阅都是唯一的,而且没有一个类似NotificationCenter通知机制 default 这样的全局单例对象。当没有订阅者时,Observable 对象不会发送通知。...在创建Observable时,在订阅任何不同的观察者之后,代码一定会添加一行 .disposed(by: disposeBag) 代码,而 disposeBag 是之前全局创建生成的let disposeBag

    1.5K20

    Rxjs源码解析(一)Observable

    和 operator,这是为了方便链式操作,在当前版本中,官方已经不建议开发者直接调用这个方法了,主要是供给 rxjs内部众多的 operators 使用forEachforEach(next: (value...,因为很多需要 forEach的场景完全可以用操作符来代替,比如针对forEach源码中给的一个使用例子import { interval } from 'rxjs';import { take } from...对象转换成了一个 Promise 对象,会在 .then的时候返回这个 Observable最后一个值,这个方法已经被标记为 deprecated了,将会在 v8.x 中被移除,并且作者在源码注释里建议我们使用...、Subscription 部分的代码还是比较简单的,并没有什么七拐八拐的逻辑,官方源码中的注释也非常详细(甚至在注释里写 example),简直就是在文档里写代码,再加上 ts的助攻,可以说源码看起来没啥难度...,当然了,这只是 rxjs 系统中两个最基础的概念,一般情况下使用 rxjs 是不会用到这两个概念的,Subject 和 operators 才是常客

    1.7K50

    Observable Platform 5:PromQL, LogQL and TraceQL

    历史在PromQL、LogQL和TraceQL之前,业界在查询和分析监控指标、日志和链路时使用了不同的方法和工具。...管理员可以使用SNMP查询来获取各种性能指标。自定义脚本:系统管理员和运维团队通常编写自定义脚本来定期收集和汇总性能指标,并将它们存储在数据库中。...PromQL、LogQL和TraceQL之所以在监控和日志分析社区中备受欢迎,是因为它们提供了强大而灵活的工具来查询、分析和可视化监控、日志和分布式追踪数据。...标准化:这些查询语言已成为标准,广泛应用于监控、日志聚合和分布式追踪工具中。它们的标准化使得不同工具之间的交互性更强,用户可以在不同的工具之间共享查询经验。...它是为了满足日志数据查询和分析的需求而设计的,并在开源社区中得到广泛接受。TraceQL 历史: TraceQL的历史取决于使用的分布式追踪系统。

    31610

    两步使用 LiveData 替换 Observable Field

    默认情况下,普通函数和字符串是不可观察的,这就意味着,当您在数据绑定布局中需要使用它们时,只能在新建的时候获取它们的值,但在后续的操作中,却不能得到相应的数据。...这里我们将其统称为 “Observable Fields”。 再后来,在我们发布 Android 架构组件时首批就包含了 LiveData,这是另一个 “可观察” 类,并且与数据绑定库兼容。...LiveData 可以感知生命周期,这一点与 Observable Fields 相比并没有多大优势,因为 Data Binding 原本就可以检查视图活跃情况。...第一步: 用 LiveData 替换 Observable Fields 如果您是直接在数据绑定中使用 Observable Fields,只需将 Live ObservableSomething (或...我们也在 2019 年的 Android Dev Summit 上发布了一个与 LiveData 相关的视频,如下: 视频内容

    1.1K20

    继续解惑,异步处理 —— RxJS Observable

    有一个形象的比喻: 你订了一个银行卡余额变化短信通知的服务,那么这个时候,每次只要你转账或者是购买商品在使用这张银行卡消费之后,银行的系统就会给你推送一条短信,通知你消费了多少多少钱; 这个场景下,银行卡余额就是...Observable,用户就是 Observer,用户在银行办理这个服务,就是 Subscription,银行卡余额发生转账或购买商品产生了变动,就是 Operator。...('bar'), 1000); }); 我们可以调用 Observable.create 方法来创建一个 Observable,入参是 observer,在函数内部通过调用 observer.next(...) 便可生成有一系列值的一个 Observable。...多播(即一个Observable,多个subscribe): ---- 以上就是关于 RxJS Observable 进一步在概念上的解惑~~ 觉得还不错,点个赞吧 更多推荐阅读: RxJS——给你如丝一般顺滑的编程体验

    1.1K30

    两步使用 LiveData 替换 Observable Field

    默认情况下,普通函数和字符串是不可观察的,这就意味着,当您在数据绑定布局中需要使用它们时,只能在新建的时候获取它们的值,但在后续的操作中,却不能得到相应的数据。...这里我们将其统称为 “Observable Fields”。 再后来,在我们发布 Android 架构组件时首批就包含了 LiveData,这是另一个 “可观察” 类,并且与数据绑定库兼容。...LiveData 可以感知生命周期,这一点与 Observable Fields 相比并没有多大优势,因为 Data Binding 原本就可以检查视图活跃情况。...综上,我们推荐您使用 LiveData。方法也非常简单,只需要两个步骤。...第一步: 用 LiveData 替换 Observable Fields 如果您是直接在数据绑定中使用 Observable Fields,只需将 Live ObservableSomething (或

    19810

    谈谈FRP和Observable(一)

    在使用方面,Observable是lazy的。cold Observable只有在 subscribe 的那一刻才被调用,hot Observable只有在 connect 发生的那一刻才开始服务。...(更多marble diagram,见:rxmarbles.com) 如果你翻看文档,微软为Observable精心定义了上百种chainable的操作,可以应付大部分使用的场景。...(访问代码请移步:jsbin.com/leroru/edit) 稍稍解释一下代码: 为了便于标注Dom element,我使用了jQuery经典的$前缀;为了便于标注Observable,我使用了$后缀...$基础上做了个 flatMapLatest(searchWiki),将 [abc, abcde, …] 转换成 [abc在wiki搜索的结果,abcde在wiki搜索的结果, …] searchWiki...实际上在java/clojure/C#等代码中,都可以以相同的方式使用Observable,当然,你也可以将RxJs应用在node程序中。这是个 一次学习,到处受益 的思想。

    1K70

    Observable 和 数组的区别

    主要是两点: 延迟运算 渐进式取值 延迟运算 延迟运算很好理解,所有 Observable 一定会等到订阅后才开始对元素做运算,如果没有订阅就不会有运算的行为 var source = Rx.Observable.from...image.png Observable operator 的运算方式跟数组的是完全的不同,虽然 Observable 的 operator 也都会回传一个新的 observable,但因为元素是渐进式取得的关系...filter 被过滤掉 送出 2 到 filter 在被送到 map 转成 3,送到 observer console.log 印出 送出 3 到 filter 被过滤掉 每个元素送出后就是运算到底,在这个过程中不会等待其他的元素运算...这就是渐进式取值的特性,不知道读者们还记不记得我们在讲 Iterator 跟 Observer 时,就特别强调这两个 Pattern 的共同特性是渐进式取值,而我们在实作 Iterator 的过程中其实就能看出这个特性的运作方式...image.png 渐进式取值的观念在 Observable 中其实非常的重要,这个特性也使得 Observable 相较于 Array 的 operator 在做运算时来的高效很多,尤其是在处理大量资料的时候会非常明显

    52520
    领券