草庐IT

rxjs-tslint-rules

全部标签

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 - 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 - rxjs 在 map Rx.Observable.range(1, 5).map 中使用 async/await

我想使用async/await从rxjs获取列表。我该怎么办?functiongetData(num){returnnewPromise((resolve,reject)=>{resolve(num+1)})}asyncfunctioncreate(){varlist=awaitRx.Observable.range(1,5).map(async(num)=>{constdata=awaitgetData(num)returndata}).toArray().toPromise()returnlist}Rx.Observable.fromPromise(create()).subscr

javascript - RxJS,Observable,如何保存值并将映射切换到另一个

//ticker$willupdateevery3s//showHand$willonlytrigerafteruserclickbutton//IwouldliketotakelasttickerpriceasuserorderpricewhenuserclickbuttonletlastPrice:number;this.ticker$//WhatIamdoingnowispreservevaluetovairablehere..do(ticker=>lastPrice=ticker.closePrice).switchMap(()=>this.showHand$).subscri

javascript - 禁止开发者禁用任何 TSLint 规则

我正在领导一个从事Angular2+/Typescript项目的团队,我只想知道是否有办法禁止禁用任何TSLint规则。我们正在使用VSCode,我的团队的开发人员倾向于禁用多行规则:点击“为该行禁用规则‘typeof-compare’”后,TSLint在禁用该行规则的行上方添加注释。 最佳答案 您不能强制或阻止人们在他们的环境中禁用任何规则。最后,这是他们的环境,他们应该有足够的自由去做事。您可以做的是在CI级别或提交级别强制执行您的tsLint规则。确保您的源代码符合您指定的任何编码风格。更新:根据您的需要,代码审查或结对编程是

javascript - Rxjs toPromise 行为不同于可观察的行为

我有一个简单的例子,其中有两个方法创建并返回一个promise。第二个方法buildRedCar()调用第一个方法buildCar(),修改promise返回的值并返回另一个promise。然后,代码调用buildRedCar(),并仅通过控制台记录结果。这在转换为promise时不起作用,但在使用直接可观察对象时它确实起作用。不有效:import*asRxfrom'rx';functionbuildCar():Rx.IPromise{letcar='Car';returnRx.Observable.just(car).toPromise();}functionbuildRedCar(

javascript - SystemJS 未找到 RxJS 根目录

SystemJS似乎可以毫无问题地加载rxjs模块,但会在rxjs目录本身上抛出404NotFound。所有模块都是最新版本,这似乎只是Windows上的问题,它适用于osx。获取http://localhost:8080/node_modules/rxjs/404(未找到)错误:错误:XHR错误(404未找到)XHR完成加载:GET"localhost:8080/node_modules/rxjs/Subject.js"。XHR完成加载:GET"localhost:8080/node_modules/rxjs/operator/toPromise.js"。Moduleloads&Er