草庐IT

rxjs_observable

全部标签

javascript - 如何在 observableArray 中订阅 observable

我正在使用KnockoutJS并尝试订阅位于observableArray中的observable。所以我的viewModel看起来像这样......functionviewModel(){//privatepropertiesvarself=this;//publicpropertiesself.movies=ko.mapping.fromJS([]);//subscriptionsself.movies.UserMovies.Rating.subscribe(function(newValue){console.log(newValue);});}moviesobservableA

javascript - Angular 2 将 APP_BASE_HREF 设置为来自 Promise/Observable 的值

我尝试使用来自异步rest调用的值在“CoreModule”中设置APP_BASE_HREF。我看不出这是怎么做到的,因为provide方法需要返回一个字符串。例如:@NgModule({imports:[...HttpModule],...providers:[......BackendRequestClass,{provide:APP_BASE_HREF,useFactory:()=>()=>return'/some/path',deps:[],multi:true}],});但是当我需要网络服务的值时,我无法返回字符串。知道如何做到这一点吗?谢谢 最佳

javascript - 将 RxJS 与 filter(Boolean) 一起用于查询?

我正在阅读一些代码片段:search(query:string){of(query).pipe(filter(Boolean),debounceTime(300),filter(Boolean)本质上和filter(v=>!!v)是一样的吗? 最佳答案 是的,它们是一样的。console.log(typeofBoolean);//printsfunctionconsole.log(Boolean.prototype.constructor("truthy"));//printstrueconsole.log(Boolean===Bo

javascript - 我如何解析另一个 Observable 中的一个 Observable? - RXJS

我有一个Observable,我在其中使用了另一个observable,但是第二个Observable我无法解析。这是代码:returnObservable.fromPromise(axios(config)).map(res=>{return{accessToken:res.data.access_token,refreshToken:res.data.refresh_token}}).map(res=>{return{me:getMe(res.accessToken),accessToken:res.accessToken,refreshToken:res.refreshToken

javascript - 为每个订阅者评估的 rxjs map 运算符

为什么map运算符针对每个订阅者而不是一次进行评估?constobs1=Rx.Observable.interval(1000).take(1).map((x,i)=>{console.log(i+1+':1map')return'obs1';})constobs2=Rx.Observable.interval(1300).take(1).map((x,i)=>{console.log(i+1+':2map')return'obs2';})constobs3=Rx.Observable.interval(1700).take(2).map((x,i)=>{console.log(i+1

javascript - Cold observable 和 Replay subject 之间的区别?

我可以从文档中看到:ColdObservables从一开始就向每个Observer发出整个值序列。和ReplaySubject向任何观察者发送源Observable发出的所有项目,无论观察者何时订阅。那么这两个概念有什么区别呢?谢谢 最佳答案 一旦ReplaySubject订阅了源observable,源就开始发射,并且ReplaySubject成为一个热的observable。从订阅者的Angular来看,订阅ReplaySubject可能并不明显,因为它获取了所有先前发出的值。但是ReplaySubject只订阅源一次,因此主题

javascript - RxJS Observable 返回数组,每次数组迭代运行另一个函数

我有一个函数getNews(),它基本上返回angular的http.get请求。请求的结果是Id的数组。我想遍历我得到的这个数组并运行另一个http.get请求(函数getItem(id)),然后它将返回从服务器接收的单个Id的对象。我试过这样使用它:getLatest(){returnthis.http.get('all_news_url').map(res=>res.json())//IeventriedcreatingObservablefromarrayandgetonly5elements//.map(res=>Observable.from(res.json()))//.

javascript - 如何使用 RxJS 显示一个 "user is typing"指标?

我知道一点BaconJS,但现在我正尝试通过创建“用户正在输入...”指示器来学习RxJS。这很简单,可以用两个简单的规则来解释:当用户输入时,指示符应该立即可见。当用户停止打字时,指示器应在用户最后一次打字后1秒内仍然可见。我不确定这是否正确,但到目前为止我已经创建了两个流:每秒发出一个0的心跳流。用于捕获用户键入事件并为每个事件发出1的流。然后我将它们合并在一起,然后简单地利用结果。如果它是1,那么我会显示指示器。如果它是0,那么我会隐藏指示器。这是它的样子:constshowTyping=()=>$('.typing').text('Useristyping...');const

javascript - 如何重复 ajax 请求,直到满足 RxJS Observable 的条件?

我正在尝试重复请求,直到响应包含使用RxJS的数据,此时我想调用成功(或失败)处理程序,但我在使用RxJS时遇到了麻烦。这是我目前的做法://...redux-observableactionobservable.mergeMap(()=>fetchData().repeatWhen(response=>response.takeWhile(({data})=>!data.length).of(response))).map(successFunction).catch(failureFunction);免责声明:我对RxJS很陌生.... 最佳答案

javascript - Event.observe(window, "load", function(){..} v/s window.onload = function(){..}

即使两者做同样的事情,我只想知道使用一个比另一个有什么特别的优势吗?Event.observe(window,"load",function(){//dosomething});window.onload=function(){//dosomething} 最佳答案 区别在于window.onload是在DOMLevel0事件模型中定义的,将清除所有早期注册的事件。这是来自旧API的“native”调用。来自原型(prototype)javascript框架的Event.observe将确定可用的最佳事件附加器。外观模式。在现代浏览