Angular路由加载子组件数据变化的解决方案

该篇是介绍父组件接收子组件的数据变化 的一种方式,解决的场景比较特殊是子组件是通过路由填充加载的 ,就是<router-outlet> </router-outlet> + 路由加载,这种情况下正常思路使用双向绑定、 xChange 向上传递是行不通的,试过 @ViewChild() 方式也取不到子组件。

另一个点是 router-outlet 是根据路由变化加载不同加载组件的,说个场景:

  1. 当导航位于"表单设计"时,展示右侧保存按钮,并且内容区展示表单设计器,当点击公开发布时保存按钮会隐藏,会切换至公开表单的选项内容
  2. 当表单内容新增/修改/删除时,保证父组件保存的控件信息和设计器里的一致

路由配置是:

遇到这种情况,是有点费脑筋的,怎么解决呢?

解决方式

RouterOutlet activate 属性

这种方式是该篇介绍的主题,RouterOutlet activate 这个方式算是冷门

activate 挂载在 router-outlet 上的事件,当 router-outlet 占位的组件被激活时就会触发,事件返回的参数是子组件,使用如下:

html 复制代码
    <router-outlet (activate)="loadComponent($event)" (deactivate)="disconnectComponent($event)"></router-outlet>
typescript 复制代码
    loadComponent(component: ComponentType<any>) {
      	console.log('激活的组件:', component);
        if (component instanceof AppFormDesignerComponent) {
          this.plugins$ = component.pluginsChange.subscribe(result => {
          });
        }
      }
      disconnectComponent(component: ComponentType<any>) {
        console.log('取消激活的组件:', component);
        if (component instanceof AppFormDesignerComponent) {
          this.plugins$.unsubscribe();
        }
      }

子组件 AppFormDesignerComponent

typescript 复制代码
    pluginsChange = new EventEmitter<FormPluginInfo[]>();

    onPluginsChange(plugins: FormPluginInfo[]) {
       this.pluginsChange.emit(plugins);
    }

效果:

万能大法:中间层介入(RxJS)

哪里流传的那么一句话: 任何解决不了的问题都可以引入一个第三方去解决。

使用 Service 或 Store,声明 RxJS Subject,父组件去订阅 Subject,子组件发送数据变化。如果只是为了解决这一种场景,比起第一种,这种引入一个 Service 显然有点大材小用。 Ps:不写示例代码了,如果有需要,可以留言。

路由传递变化函数

可以在路由跳转的时候传递变化的函数,该函数绑定父组件的上下文并将写好逻辑委托给子组件,当子组件发生变化时执行一下,可以达到更新数据的效果。

路由守卫

第二种方式并不完美,一般来说 访问父组件的路由会自动跳转重定向到第一个菜单,这种情况还需要初始数据,在路由守卫里获取父/子的组件信息 ,没有去实践,越往深想好像越复杂,所以还是推荐用前两种方式吧。

最后

就以上场景而言,个人更倾向 RouterOutlet activate 这种解决方式,简单且全面。

欢迎点赞,关注和留言 🌹

参考

相关推荐
蟾宫曲2 小时前
在 Vue3 项目中实现计时器组件的使用(Vite+Vue3+Node+npm+Element-plus,附测试代码)
前端·npm·vue3·vite·element-plus·计时器
秋雨凉人心2 小时前
简单发布一个npm包
前端·javascript·webpack·npm·node.js
liuxin334455663 小时前
学籍管理系统:实现教育管理现代化
java·开发语言·前端·数据库·安全
qq13267029403 小时前
运行Zr.Admin项目(前端)
前端·vue2·zradmin前端·zradmin vue·运行zradmin·vue2版本zradmin
魏时烟4 小时前
css文字折行以及双端对齐实现方式
前端·css
2401_882726485 小时前
低代码配置式组态软件-BY组态
前端·物联网·低代码·前端框架·编辑器·web
web130933203985 小时前
ctfshow-web入门-文件包含(web82-web86)条件竞争实现session会话文件包含
前端·github
胡西风_foxww5 小时前
【ES6复习笔记】迭代器(10)
前端·笔记·迭代器·es6·iterator
前端没钱5 小时前
探索 ES6 基础:开启 JavaScript 新篇章
前端·javascript·es6
m0_748255266 小时前
vue3导入excel并解析excel数据渲染到表格中,纯前端实现。
前端·excel