Rxjs监听精确使用版本上线

 更新时间:2022年08月07日 09:33:03   作者:前端analysis  
这篇文章主要为大家介绍了Rxjs监听使用不精确版本上线晚3小时,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

导语

最近在开发新feature,周五需要版本合并,上线。可是从DevTool Network请求记录来看,每次界面加载完毕,异步条件触发,filter api 都是调用2遍。

根据日志,定位带有嫌疑code位置。 code多请求一次,对服务器、用户体验都是不能接受的,版本是不可能上线的。

思路

问题可不可以本地复现?

可以,那就好办了

是不是,条件触发了2遍 ?

注释掉一个触发条件

# 留下的代码大致如下
private searchCondition$ = new Subject();
this.searchCondition$.next({
...(searchParam || {} ) 
...param,
});

...解构是2次,是不是这里导致的?

可是...解构代码是同步操作,之后才执行到next。多添加一个...试试,不过还是只有2次调用

 this.searchCondition$.next({
   ...(searchParam || {} ) 
   ...param,
   ...{a:1,}
 });

既然next异步触发不行,代码也不复杂,就重写直接同步调用

this.requestData({
   ...(searchParam || {} ) 
   ...param,
 });

经过测试,还是调用2次,那么问题就不是出现在发的地方

那就是监听的地方,触发了2遍

查看界面监听也就是subscribe()的地方

# 在html自定义组件中存在两处这样的代码
<cus-component [dataset]="dataset$ | async "> </cus-component>
# 这是ts监听地方
this.dataset$ = this.getDataLine(searchParam).pipe(
   switchMap((res) => {
       ...
       return of(res)
   }),
)

上述代码,通过注释掉一处html引用,编译后发现,调用次数变为1.故出现问题的代码就算定位到了。那么怎么fix?

修改代码,不监听http请求返回,直接把得到的数据返回给界面展示

 const sub = this.getDataLine(searchParam).pipe(
    tap((res) => {
        ...
        this.dataset$ = of(res)
    }),
 )
 //添加subscribe句柄管理,在component destory时候,销毁释放
 this.subs?.add(sub);

添加配置,屏蔽掉多次调用结果

//设置利用最后一次的值
 shareReplay(1)

拓展:

Expression Changed After Checked

原因:

只有开发环境才有,用于提示html绑定的变量多次修改了,界面还没来及更新。

解决办法:

  • 方法一:把code修改的地方,添加上setTimeout,延迟去刷新界面
  • 方法二: 针对code,改用Observable, html界面使用上async

You provided an invalid object

TypeError: You provided an invalid object where a stream was expected. 
You can provide an Observable, Promise, Array, or Iterable

可能原因:

最直接的从错误字面意思来,就是提供的对象,是一个不可用的对象,需要fix

解决办法

直接在报错的时候,debug,跳转到报错的位置,查看stack里面的内容,里面会清晰告诉你那里有错误。

常见的解决办法

  • 判定返回的对象是否undefined
  • 添加? or if等支持, 判定对象的方法调用,譬如 chart.draw() , chart不能为null,undefined.

总结

通过查看文档、debug,把控制台的错误一个个fix了,版本最终部署上线。出现错误,不要怕,不过上线上晚了,确实有点影响哈~ 。

到此这篇关于Rxjs监听精确使用版本上线的文章就介绍到这了,更多相关Rxjs监听版本上线内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 微信小程序 下拉菜单简单实例

    微信小程序 下拉菜单简单实例

    这篇文章主要介绍了微信小程序 下拉菜单简单实例的相关资料,需要的朋友可以参考下
    2017-04-04
  • 不可变数据方案之immer.js原理解析

    不可变数据方案之immer.js原理解析

    这篇文章主要为大家介绍了不可变数据方案之immer.js原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 微信小程序 教程之注册页面

    微信小程序 教程之注册页面

    这篇文章主要介绍了微信小程序 注册页面的相关资料,需要的朋友可以参考下
    2016-10-10
  • JS中this的4种绑定规则详解

    JS中this的4种绑定规则详解

    如果你学过面向对象编程,那你肯定知道干什么用的,如果你没有学过,那么暂时可以不用看这篇文章,this既不指向函数自身,也不指函数的词法作用域,具体怎么使用JS中的this,JS中的this绑定规则又是什么?
    2020-02-02
  • canvas 中如何实现物体的框选

    canvas 中如何实现物体的框选

    这篇文章主要为大家介绍了canvas中如何实现物体的框选的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 前端JavaScript彻底弄懂函数柯里化curry

    前端JavaScript彻底弄懂函数柯里化curry

    随着主流JavaScript中函数式编程的迅速发展, 函数柯里化在许多应用程序中已经变得很普遍。 了解它们是什么,它们如何工作以及如何充分利用它们非常重要。本篇文章小编九向大家详细介绍JavaScript函数柯里化,需要的小伙伴可以参考下面文字内容
    2021-09-09
  • 微信小程序 toast 详解及实例代码

    微信小程序 toast 详解及实例代码

    这篇文章主要介绍了微信小程序 toast 详解及实例代码的相关资料,需要的朋友可以参考下
    2016-11-11
  • 微信小程序  简单实例(阅读器)的实例开发

    微信小程序 简单实例(阅读器)的实例开发

    这篇文章主要介绍了微信小程序 简单实例(阅读器)的实例开发的相关资料,需要的朋友可以参考下
    2016-09-09
  • 微信小程序 表单Form实例详解(附源码)

    微信小程序 表单Form实例详解(附源码)

    这篇文章主要介绍了微信小程序 表单Form实例详解的相关资料,这里对form 表单进行了详细介绍,并附实例代码,需要的朋友可以参考下
    2016-12-12
  • 微信小程序通过api接口将json数据展现到小程序示例

    微信小程序通过api接口将json数据展现到小程序示例

    这篇文章主要介绍了微信小程序通过api接口将json数据展现到小程序示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01

最新评论