【Abp VNext】实战入门(五):【9】前端管理界面 vue-element-admin —— Router路由跳转及参数传递

一、前言:

除了常规的通过标签link形式跳转页面的方法,vue-element-admin 项目中已经自带路由封装,可以在代码中手动控制页面路径跳转, 通常只需要知道如何跳转页面,如何传递参数即可。

配合底层路由拦截功能,参考:【Abp VNext】实战入门(五):【2】前端管理界面 vue-element-admin —— 路由拦截优化改造

二、必须的页面路径申明配置:

描述:所有页面要进行展示都必须先在路由页面中先行声明(名称、路径…)

1、在根目录router/index.js 中配置写好的vue页面:
在这里插入图片描述

2、简单声明页面不在菜单显示:
这种页面打开后不带左边菜单、不带顶部导航栏、全屏显示

  {
    path: '/login',
    component: () => import('@/views/login/index'),
    hidden: true //隐藏申明 不在菜单中显示
  },

类似于这样:
在这里插入图片描述

3、一级菜单声明:
在这里插入图片描述

{
    path: '/device',//访问主路径如:http://localhost:9528/#/device
    name: '监控首页',//貌似每个卵用 要不要都不影响
    component: Layout, //页面采用 框架模板 打开后自带左侧菜单 顶部导航栏
    redirect: '/device/index', //打开主路径后默认跳转index.vue页面:http://localhost:9528/#/device/index 
    meta: { title: '监控首页',  //左侧一级菜单标题
    		icon: 'el-icon-s-help'  //一级菜单图标
    	  },
    children: [{ //一级菜单下面的二级菜单可以有多个
      path: 'index', //二级菜单路径 device/index 就是这么来的 
      name: 'index', //名称 也没什么卵用
      component: () => import('@/views/device/index'), //二级菜单的绝对物理路径
      meta: { title: '系统首页', icon: 'dashboard' }//二级菜单名字、图标
    }]
  },

界面效果:
在这里插入图片描述

4、多级菜单申明:

{
    path: '/device',//访问主路径如:http://localhost:9528/#/device
    name: '监控首页',//貌似每个卵用 要不要都不影响
    component: Layout, //页面采用 框架模板 打开后自带左侧菜单 顶部导航栏
    redirect: '/device/index', //打开主路径后默认跳转index.vue页面:http://localhost:9528/#/device/index 
    meta: { title: '监控首页',  //左侧一级菜单标题
    		icon: 'el-icon-s-help'  //一级菜单图标
    	  },
    children: [
    { //一级菜单下面的二级菜单可以有多个
      path: 'index', //二级菜单路径 device/index 就是这么来的 
      name: 'index', //名称 也没什么卵用
      component: () => import('@/views/device/index'), //二级菜单的绝对物理路径
      meta: { title: '系统首页', icon: 'dashboard' }//二级菜单名字、图标
    },
    { // 一级菜单下面的二级菜单
      path: 'detail',
      name: 'detail',
      component: () => import('@/views/device/detail'),
      meta: { title: '控制页面', icon: 'form' },
      //hidden: true //如果隐藏了 左侧只显示 index菜单
    }   ]
  },

界面效果:
在这里插入图片描述

三、页面跳转:

1、简单跳转:

//index.vue
const tmpPath = { path: './detail'}
this.$router.push(tmpPath)
this.$router.push('./detail') //一样的

2、带参数跳转(1):

//index.vue
const tmpPath = { path: './detail',query: { id:2 }}
this.$router.push(tmpPath)
this.$router.push('./detail?id=3') //一样的
//detail.vue 获取参数
  created() {
	let tmpID = this.$route.query.id //注意是this.$route 不是 router 没有r
    console.log(tmpID )
  },

3、带参跳转(2):

<router-link target="_blank" :to="{path:'./detail',query:{id: "2"}}">跳转1</router-link>

//detail.vue 获取参数
let tmpID = this.$route.query.id

四、总结:

还有其他很多跳转方法后续用到了再补

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于vue-element-admin左侧菜单的问题,有以下几个引用内容提供了解决方法: 引用提到了解决左侧菜单收缩时图标不垂直居中的问题。可以在styles/sidebar.css文件中找到.sidebar-container的样式,并将宽度从54px改为64px。 引用提到了如何从后台获取由信息并更新左侧菜单。首先,需要将后台返回的菜单数据保存到vuex状态管理中。然后,在组件中从vuex状态管理中获取菜单数据,并传递给子组件。最后,将默认的从由表获取数据的代码注释掉,根据后台返回的属性名来修改相应的代码。 引用提到了在login文件下的index.vue中,可以找到相关接口的位置。此外,如果登录接口成功但无法进入页面,则需要检查store/modules/permission.js文件中getUserPowers方法的返回值是否正确。 根据以上引用内容,您可以按照这些方法来解决vue-element-admin左侧菜单的问题。123 #### 引用[.reference_title] - *1* [【Abp VNext实战入门(五):【13】前端管理界面 vue-element-admin —— 左侧菜单自定义图标及图标大小...](https://blog.csdn.net/liuyonghong159632/article/details/114224640)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *2* [【vue】vue动态展示左侧菜单](https://blog.csdn.net/qq_42021376/article/details/116143490)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *3* [vue+elementUI+admin左侧菜单权限、动态由](https://blog.csdn.net/RYNTina/article/details/105280607)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值