【Vue-router】解决父级路由不需要 component的情况

问题描述

后台系统页面中动态配置菜单,只有二级菜单有相应前端组件,一级菜单只是展示作用;
所以,出现 只设置二级路由,但一级路由不需要 component 的特殊需求;

看下页面展示:(移入一级菜单就弹出二级菜单,所以二级菜单才会有相对应的前端组件)
在这里插入图片描述

[{
    id:8,
    path: '/WryModule',
    name: '',
    meta: {
        title: '污染源在线监测'
    },
    component: '', //这里是空的情况
    systemTypeCode:'pollution',
    children: [
        {
            pid:8,
            path: '/WryModule/RealView',
            name: 'WryRealView',
            meta: {
                title: '实时一览'
            },
            component:'views/PageBigData/WryModule/RealView',
            systemTypeCode:'pollution',
        },
        {
            pid:8,
            path: '/WryModule/DataQuery',
            name: 'WryDataQuery',
            meta: {
                title: '数据查询'
            },
            component:'views/PageBigData/WryModule/DataQuery',
            systemTypeCode:'pollution',
        },
     ]
}]
解决办法

component 写成component: {render: (e) => e("router-view")}

实际应用

根据后台系统管理平台,配置好菜单/路由数据结构,动态生成路由;
注册component的时候判断 有无组件,没有组件的父级路由,就设置component:component: {render: (e) => e("router-view")}
在这里插入图片描述

  • 15
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
vue-router 中的嵌套路由允许我们在一个组件中嵌套多个子组件。通过使用嵌套路由,我们可以将应用程序的不同部分组织成层次结构,更好地管理和维护我们的代码。 嵌套路由的主要概念是在组件中定义一个 `<router-view>` 组件,而子组件则通过在组件中的路由配置中设置 `component` 属性来渲染到 `<router-view>` 中。这样,每个子路由都可以有自己的组件,并且它们会在组件的 `<router-view>` 中根据路由的路径匹配进行渲染。 嵌套路由在编写大型应用程序时非常有用,因为它们允许我们将整个应用程序的不同功能和页面分解为更小的、可重用的组件。这样,我们可以更加灵活地构建和管理我们的应用程序,从而提高我们的开发效率。 对于嵌套路由的使用,我们需要路由配置文件中定义组件路由和子组件路由。在组件路由配置中,我们需要设置 `children` 属性,然后在该属性下定义子组件路由。这样,当我们访问组件路由时,子组件路由也会被加载和渲染。 总结起来,Vue Router 的嵌套路由允许我们将应用程序的不同部分组织成层次结构,以更好地管理和维护我们的代码。通过在组件中定义 `<router-view>`,并在路由配置中设置 `component` 属性,我们可以将不同的子组件根据路由的路径匹配进行渲染。嵌套路由的使用使得应用程序更具有可重用性和灵活性,从而提高了开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值