草庐IT

rxjs-test-scheduler

全部标签

javascript - 订阅/取消订阅 Rxjs Subject 时如何接收通知

我正在尝试使用Rxjs来管理大型状态树中的垃圾回收。我如何创建一个运算符来接受每次可观察对象的订阅者数量发生变化时触发的回调函数? 最佳答案 多种方式,都涉及隐藏您的主题并为消费者提供包装的可观察对象:想知道什么时候有人订阅了您的主题吗?constsubject=newSubject();constobservable=Observable.defer(()=>{someoneJustSubscribed();returnsubject;});returnobservable;想知道有人何时取消订阅?constsubject=new

javascript - rxjs 科目应该在类里面公开吗?

假设我有两个类,您可以在其中观察一些可观察值。第一个例子,带有公共(public)主题:classEventsPub{publicreadonlyonEnd=newSubject();}第二个例子,私有(private)主题和注册方法:classEventsPriv{privatereadonlyendEvent=newSubject();publiconEnd(cb:()=>void):Subscription{returnthis.endEvent.subscribe(cb);}}第一个示例在某种程度上是不安全的,因为任何人都可以从类外部调用eventsPub.endEvent.n

javascript - 如何在规范文件中注入(inject)服务 Angular Testing (Jasmine/karma)

我刚开始编写Angular单元测试用例。我在我的Controller文件(.ts)中注入(inject)一项服务。我将如何在规范文件中注入(inject)服务文件。代码如下:app.component.tsgetSortData(){this.sortService.sortNumberData(this.data,'name','asce');}sort.service.tssortNumberData(data,rendererKey,type){//data.sort((elem1,elem2)=>{////ifnumberisundefined,thenassigning`MA

javascript - '错误 : Unexpected request' during Karma Angular Unit Test

运行gruntkarma时,其中一个指令的测试在尝试获取模板时失败。我使用ng-html2js作为预处理器。这是我的一些karma.conf.jsplugins:['karma-chrome-launcher','karma-jasmine','ng-html2js','karma-ng-html2js-preprocessor'],preprocessors:{'app/scripts/directives/**/*.html':'ng-html2js'},ngHtml2JsPreprocessor:{moduleName:'templates'}在我的测试中,我有以下内容:'use

javascript - RxJS - 捕获并继续

我正在努力按照我预期的方式处理Rx的错误。当我有一个Observable(例如,来自点击流)并且发生异常时,我想捕获它但继续。我尝试过的所有解决方案都会捕获错误然后结束Observable。有没有办法捕获并继续下去?例如,下面的Observable将发出“1”,然后是“Error”,但永远不会发出“3”。varrange=Rx.Observable.range(1,3).map(function(i){if(i===2){throw"Error";}else{returni;}}).catch(function(e){returnRx.Observable.return(e)});ra

javascript - Angular 2 rxjs 嵌套 Observables

我希望创建一个返回Observable的函数但在返回之前必须完成另一个异步任务(一个Observable),以便将值传递给返回的Observable.@Injectable()exportclassMyComponent{GetAuthToken=function():Observable{returnthis._storageService.GetAsString('authToken');}GetData=function(authToken):Observable{letheaders=newHeaders();headers.append('authToken',authTok

javascript - rxjs 观察数组推送

我想使用observables来监控对象何时被推送到数组中。我想从一个空数组开始,当发生推送时,我希望observable检测并处理它,然后等到下一次推送。这与可观察者等待事件的“fromEvent”非常相似。下面的代码立即调用completed()因为数组是空的,我如何让它等待推送?vartestArray=[];test(){varo={timestamp:newDate()}testArray.push(o)}varo=Observable.from(testArray).concatMap(x=>{returnx;});o.subscribe(x=>{console.log("

rxjs - RxJS 中的 map 和 pluck 有什么区别?

我试图理解map之间的区别和pluckRxJS中的转换运算符。谁能帮我解决这个问题? 最佳答案 文档说Pluck:Likemap,butmeantonlyforpickingoneofthenestedpropertiesofeveryemittedobject.因此,假设你有[{name:'Joe',age:30,job:{title:'Developer',language:'JavaScript'},{name:'Sarah',age:35}]并且您想要一份包含所有职位的列表。使用map会有点痛苦(因为job的可空性),但是使

javascript - RxJs:zip 运算符的有损形式

考虑使用zip运算符将两个无限的Observable压缩在一起,其中一个发出的数据项的频率是另一个的两倍。当前的实现是无损的,即如果我让这些Observable发射一个小时,然后我在它们的发射率之间切换,第一个Observable最终会catch另一个。随着缓冲区变得越来越大,这会在某个时候导致内存爆炸。如果第一个observable将在几个小时内发出项目,而第二个将在最后发出一个项目,则会发生同样的情况。如何实现此运算符的有损行为?我只想在我从两个流中获得排放时进行排放,我不在乎我错过了更快的流中有多少排放。说明:我在这里尝试解决的主要问题是由于zip运算符的无损特性导致的内存爆炸。

javascript - rollup.js 中的 rxjs 不导出“主题”

我正在尝试设置我的项目以使用汇总,作为angular2迁移到AOT编译的一部分,但是,我遇到了以下问题。Error:'Subject'isnotexportedbynode_modules\rxjs\Subject.js这是我的rollup.js文件:importrollupfrom'rollup';importnodeResolvefrom'rollup-plugin-node-resolve'importcommonjsfrom'rollup-plugin-commonjs';importuglifyfrom'rollup-plugin-uglify'exportdefault{e