首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

switchmap是否会自动调用订阅?

switchMap是RxJS中的一个操作符,用于将一个Observable序列转换为另一个Observable序列。它会在每次源Observable发出新值时,自动取消先前的订阅并订阅新的Observable。

在RxJS中,订阅是手动触发的,而不是自动调用的。因此,switchMap不会自动调用订阅。它只是在源Observable发出新值时,取消先前的订阅并订阅新的Observable。

使用switchMap时,可以通过手动调用subscribe方法来订阅转换后的Observable。例如:

代码语言:txt
复制
import { of } from 'rxjs';
import { switchMap } from 'rxjs/operators';

const source$ = of(1, 2, 3);

source$.pipe(
  switchMap(value => of(value * 2))
).subscribe(result => {
  console.log(result); // 输出:2, 4, 6
});

在上面的例子中,源Observable source$发出的每个值都会通过switchMap转换为一个新的Observable,即of(value * 2)。然后,通过手动调用subscribe方法来订阅转换后的Observable,并输出结果。

需要注意的是,switchMap会在每次源Observable发出新值时,取消先前的订阅。因此,如果在转换后的Observable中存在一些异步操作,比如发起HTTP请求,当源Observable发出新值时,旧的请求会被取消,只会处理最新的请求。

关于switchMap的更多信息,可以参考腾讯云的RxJS文档:RxJS - switchMap

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Android Jetpack架构组件(四)之LiveData

UI 组件只需观察相关数据,不需要停止或恢复观察,LiveData 自动管理这些操作,因为 LiveData 可以感知生命周期状态的更改。 数据始终保持最新状态。...observe() 后,系统立即调用 onChanged(),从而提供 mCurrentName 中存储的最新值,如果 LiveData 对象尚未在 mCurrentName 中设置值,则不会调用...setValue():注意到value=price这里是调用了setValue(price)方法,通过该方法更新LiveData的值,进而通知处于活跃状态的订阅者。...此时,LiveData认为订阅者的生命周期处于STARTED或RESUMED状态时,该订阅者是活跃的,那么如何使用 StockLiveData 类呢,如下所示。...然后,判断当前observer对应组件的状态是不是Active,如果不是就会再次调用activeStateChanged方法并传入false,其方法内部会再次判断是否执行onActive方法和onInactive

3.1K00

RxJS速成 (下)

从Subject内部来讲, subscribe动作并没有调用一个新的执行来传递值, 它只是把Observer注册到一个列表里, 就像其他库的AddListener一样....作为Observer, 它是一个拥有next(), error(), complete()方法的对象, 调用next(value)就会为Subject提供一个新的值, 然后就会多播到注册到这个Subject...它有这些好处: 不必编写嵌套的subscribe() 把每个observable发出来的值转换成另一个observable 自动订阅内部的observable并且把它们(可能)交错的合成一排. ?...switchMap switchMap把每个值都映射成Observable, 然后使用switch把这些内部的Observables合并成一个. switchMap有一部分很想mergeMap, 但也仅仅是一部分像而已...多个输入的observable的值, 按顺序, 按索引进行合并, 如果某一个observable在该索引上的值还没有发射值, 那么等它, 直到所有的输入observables在该索引位置上的值都发射出来

2.1K40
  • LiveData beyond the ViewModel

    简而言之,其优点是你不需要在View和ViewModel之间手动取消订阅。...Transformations.map Transformations.switchMap 请注意,当你的View被销毁时,你不需要销毁这些订阅,因为View的lifecycle会被传播到下游后继续订阅...请注意,数据不是自动为你组合的,MediatorLiveData只是负责通知的工作。 为了在我们的示例应用程序中实现转换,我们需要将两个不同的LiveDatas合并成一个。...变换在调用时创建一个新的LiveData(包括map和switchMap)。在这个例子中,随机数(randomNumber)被暴露在视图中,但每次用户点击按钮时它都会被重新分配。...onCreate()中,所以如果之后viewmodel.randomNumber LiveData实例发生变化,观察者将不会被再次调用

    1.5K30

    浅谈前端响应式设计(二)

    在 Rxjs中,显然不会有这些问题, combineLatest可以以很简练的方式声明需要聚合的数据源,同时,得益于 Rxjs设计,我们不需要像 Mobx一个一个去调用 observe返回的析构,只需要处理每一个...在 Observable中我们可以通过 switchMap操作符处理异步问题,一个异步搜索看起来会是这样: input$.pipe(switchMap(keyword => Observable.ajax...switchMap当上游有新值到来时,忽略结束已有未完成的 Observable然后调用函数返回一个新的 Observable,我们只使用一个函数就解决了并发安全问题。...但是我们希望在路由被且走后,后台的数据依然继续。 对于事件而言,在事件发生之后的订阅者不会受到订阅之前的逻辑。...但是这在处理数据的时候造成麻烦,我们的数据在 View被卸载(例如路由切走)后丢失。

    1.1K20

    RxJS速成

    40); 这个filter function和数组的filter类似, 它接受另一个function(也可以叫predicate)作为参数, 这个function提供了某种标准, 通过这个标准可以判定是否当前的元素可以被送到订阅者那里...但是如果error function在Observer被调用了的话, 那就太晚了, 这样流就停止了....它有这些好处: 不必编写嵌套的subscribe() 把每个observable发出来的值转换成另一个observable 自动订阅内部的observable并且把它们(可能)交错的合成一排....switchMap把每个值都映射成Observable, 然后使用switch把这些内部的Observables合并成一个. switchMap有一部分很想mergeMap, 但也仅仅是一部分像而已....多个输入的observable的值, 按顺序, 按索引进行合并, 如果某一个observable在该索引上的值还没有发射值, 那么等它, 直到所有的输入observables在该索引位置上的值都发射出来

    4.2K180

    Jetpack:在数据变化时如何优雅更新Views数据

    而这些订阅者通常是UI控制器,如Activity或Fragment,以能在被通知时,自动去更新Views。 创建LiveData对象 LiveData可以包装任何数据,包括集合对象。...当然,如果此时LiveData没有存储值的话,onChange()方法不会被调用。 更新 LiveData 对象 LiveData本身没有提供公共方法更新值。...setValue() 注意到value=price这里是调用了setValue(price)方法,通过该方法更新LiveData的值,进而通知处于活跃状态的订阅者。...LiveData认为订阅者的生命周期处于STARTED或RESUMED状态时,该订阅者是活跃的。 那么如何使用StockLiveData呢?...()同样可以改变下游的结果,但传递给switchMap()的函数必须返回一个LiveData对象。

    3K30

    构建流式应用:RxJS 详解

    },250) }) 已无用的请求仍然执行的解决方式,可以在发起请求前声明一个当前搜索的状态变量,后台将搜索的内容及结果一起返回,前端判断返回数据与当前搜索是否一致...订阅:通过 addEventListener 订阅 document.body 的 click 事件。 发布:当 body 节点被点击时,body 节点便会向订阅者发布这个消息。...Observables 与 Observer 之间的订阅发布关系(观察者模式) 如下: 订阅:Observer 通过 Observable 提供的 subscribe() 方法订阅 Observable...var subscription = Observable.subscribe(Observer); RxJS 中流是可以被取消的,调用 subscribe 将返回一个 subscription,可以通过调用...Rx.Observable.prototype.switchMap switchMap 与 mergeMap 都是将分支流疏通到主干上,而不同的地方在于 switchMap 只会保留最后的流,而取消抛弃之前的流

    7.3K31

    翻译翻译什么 tmd 叫“可读”?RxJS实现“搜索”功能

    但是实际上的业务往往远大于示例中的代码,按照上面的思路,最终会写成这种玩意儿: 一点不夸张。...switchMap 要重点理解下; 官方解释是:映射成 observable,完成前一个内部 observable,发出值。...换个角度来解释: RxJS 中通常用【弹珠图】来表示“事件流”,比如 map api 的弹珠图如下: switch api 的弹珠图如下: 当发出一个新的内部 Observable 时, switch 从先前发送的内部...Observable 那取消订阅,然后订阅新的内部 Observable 并开始发出它的值。...即永远订阅最新的Observable; 那么:switchMap = map + switch ,示意如下: 结合理解,在本篇搜索示例中,即用 Http.get(url) 所得 data 值作为事件流的最新值

    56410

    从一场空难讲起:自动驾驶汽车是否让人陷入自动化悖论

    *半自动操作状态下,人类应该随时准备拿回控制权,但我们准备好了吗? 自鸣得意和技能退化:这是人类的本性,飞行员也不例外 人类是一种习惯动物,随着我们对工作逐渐熟悉,大多数人变得自鸣得意。...大多数航空公司的安全机制(训练和体检)在自动驾驶时代已经变得不切实际,因此自动化的影响肯定也冲击自动驾驶汽车市场。“Level 3 就是个可怕的点子,汽车制造商真应该赶紧甩掉它。”...举例来说,车载摄像头可以追踪驾驶员的疲劳程度,判断他是否能在紧急时刻反应过来。如果需要,车辆还会通过视觉或听觉警告来唤醒司机。 “研究显示,声音警告比视觉的要有效得多。”Clamann 说道。...在航空业,随着驾驶舱不断自动化,各种针对飞行员的教育也在加强,目的就是帮他们理解这套系统,提早发现其有害影响。 那么,汽车行业也走上这条道路,保证驾驶员能理解自动驾驶汽车吗?...Rajkumar 解释,而且即便到了那个时候,“还是会有一些事情超出任何人的控制。” 如果这听起来很可怕,也许是因为它本该如此。乍一看,汽车在情况变得复杂时,向人类交还控制权,这听起来很合理。

    90550

    调试 RxJS 第2部分: 日志篇

    它显示了所发生的一切: 订阅组合 observable 并行订阅每个用户 API 请求的 observable 请求完成的顺序是不固定的 observables 全部完成 全部完成后,组合 observable...的订阅自动取消订阅 每个日志中的通知都包含接收该通知的订阅者 ( Subscriber )的信息,其中包括订阅订阅的数量和 subscribe 调用的堆栈跟踪: ?...堆栈跟踪指向的是根源的 subscribe 调用,也就是 observable 订阅者的显式订阅。...当调试时,我发现知道实际的 subscribe 调用地点比知道位于组合 observable 中间的 subscribe 调用地点更有用。 现在我们来看一个现实问题。...解决方法是将 map 和 catch 的调用移到 switchMap 里面,就像这样: ? 这样 epic 便不会完成,它会继续 dispatch 报错的 actions: ?

    1.2K40

    Android Jetpack - LiveData

    而已注册但处于非活跃状态的观察者不会被更新 我们可以在实现了 LifecycleOwner 的接口的对象中注册 observer,这种关联允许 observer 在与之相关的 Lifecycle 对象处于 DESTROYED 状态时自动移除...尤其是 activities 和 fragments ,它们可以安全地观察 LiveData 而不必担心内存泄露 —— activities 和 fragments 在生命周期销毁时会立即取消数据观察订阅...LiveData 自动管理所有这些,因为它在观察时意识到相关的生命周期状态变化 始终保持数据最新 如果生命周期变为非活动状态,它将在再次变为活动状态时接收最新数据。...数据更改时被回调并返回最新数据,这一步通常在 UI 控制器中完成 3、使用 observer() 方法关联 Observer 和 LiveData ,observer() 方法持有 LifecycleOwner 对象,此订阅让...} } 2、观察 LiveData 对象 在大多数情况下,从 app 组件的 onCreate() 方法是开始观察 LiveData 对象最合适,原因如下: onResume() 可能被多次调用

    2K30

    ✨从异步讲起,时间,时间,请给函数以答案!

    .then(res => success(res)) .catch(err => fail(err)); }; callApiFoo(success, fail); 回调缺点就是:嵌套调用形成...— 使用前一个结果的 id 调用 callApiFooC,并返回一个新的 Observable,新 Observable 是 callApiFooC( resIds ) 的返回结果; switchMap...核心好处是分离 创建(发布)  和 调用订阅消费) 。 异步与回调的核心意义不正在于此吗?...我订阅你的博客,你发布了新内容,于是就通知我这边,好了,这样一来,我也不用干等,只要你发布了新的文章,我就可以按照自己的方式来消费它们。各干各的。...“给你一段同步代码,有 10 个函数方法调用” 和 “给你一段同步加异步的代码,其中 5 个函数方法是同步、5 个函数方法是异步”,你觉得其中哪个更易理解?

    1.1K20

    Angular进阶教程2-

    providers为这个组件创建一个注入器,这个组件的子组件\color{#0abb3c}{组件的子组件}组件的子组件也共享\color{#0abb3c}{共享}共享这个注入器,如果没有定义,那么组件根据组件树逐级向上...// 这种方式注册,注册到每个组件实例自己的注入器上。...从中我们可以发现observable的一些特性,如下所示: 必须被调用订阅)才会被执行 observable 被调用后,必须能被关闭,否则会一直运行下去 对于同一个observable,在不同的地方subscribe...observable一样去订阅subject。...常见的运算符包含 map, filter, concat, flatmap, switchmap, forkjoin 在这里我们只调挑出forkJoin和switchMap来讲解一下,其他的操作符可以自己去查阅

    4.1K30
    领券