index.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. import { createWebHistory, createRouter } from 'vue-router'
  2. import Layout from '@/layout'
  3. /**
  4. * Note: 路由配置项
  5. *
  6. * hidden: true // 当设置 true 的时候该路由不会再侧边栏出现 如401,login等页面,或者如一些编辑页面/edit/1
  7. * alwaysShow: true // 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式--如组件页面
  8. * // 只有一个时,会将那个子路由当做根路由显示在侧边栏--如引导页面
  9. * // 若你想不管路由下面的 children 声明的个数都显示你的根路由
  10. * // 你可以设置 alwaysShow: true,这样它就会忽略之前定义的规则,一直显示根路由
  11. * redirect: noRedirect // 当设置 noRedirect 的时候该路由在面包屑导航中不可被点击
  12. * name:'router-name' // 设定路由的名字,一定要填写不然使用<keep-alive>时会出现各种问题
  13. * query: '{"id": 1, "name": "ry"}' // 访问路由的默认传递参数
  14. * meta : {
  15. noCache: true // 如果设置为true,则不会被 <keep-alive> 缓存(默认 false)
  16. title: 'title' // 设置该路由在侧边栏和面包屑中展示的名字
  17. icon: 'svg-name' // 设置该路由的图标,对应路径src/assets/icons/svg
  18. breadcrumb: false // 如果设置为false,则不会在breadcrumb面包屑中显示
  19. activeMenu: '/system/user' // 当路由设置了该属性,则会高亮相对应的侧边栏。
  20. }
  21. */
  22. // 公共路由
  23. export const constantRoutes = [
  24. {
  25. path: '/redirect',
  26. component: Layout,
  27. hidden: true,
  28. children: [
  29. {
  30. path: '/redirect/:path(.*)',
  31. component: () => import('@/views/redirect/index.vue')
  32. }
  33. ]
  34. },
  35. {
  36. path: '/login',
  37. component: () => import('@/views/login'),
  38. hidden: true
  39. },
  40. {
  41. path: '/register',
  42. component: () => import('@/views/register'),
  43. hidden: true
  44. },
  45. {
  46. path: "/:pathMatch(.*)*",
  47. component: () => import('@/views/error/404'),
  48. hidden: true
  49. },
  50. {
  51. path: '/401',
  52. component: () => import('@/views/error/401'),
  53. hidden: true
  54. },
  55. {
  56. path: '',
  57. component: Layout,
  58. redirect: 'index',
  59. children: [
  60. {
  61. path: '/index',
  62. component: () => import('@/views/index'),
  63. name: 'Index',
  64. meta: { title: '首页', icon: 'dashboard', affix: true }
  65. }
  66. ]
  67. },
  68. {
  69. path: '/user',
  70. component: Layout,
  71. hidden: true,
  72. redirect: 'noredirect',
  73. children: [
  74. {
  75. path: 'profile',
  76. component: () => import('@/views/system/user/profile/index'),
  77. name: 'Profile',
  78. meta: { title: '个人中心', icon: 'user' }
  79. }
  80. ]
  81. },
  82. {
  83. path: '/system/user-auth',
  84. component: Layout,
  85. hidden: true,
  86. children: [
  87. {
  88. path: 'role/:userId(\\d+)',
  89. component: () => import('@/views/system/user/authRole'),
  90. name: 'AuthRole',
  91. meta: { title: '分配角色', activeMenu: '/system/user' }
  92. }
  93. ]
  94. },
  95. {
  96. path: '/system/role-auth',
  97. component: Layout,
  98. hidden: true,
  99. children: [
  100. {
  101. path: 'user/:roleId(\\d+)',
  102. component: () => import('@/views/system/role/authUser'),
  103. name: 'AuthUser',
  104. meta: { title: '分配用户', activeMenu: '/system/role' }
  105. }
  106. ]
  107. },
  108. {
  109. path: '/system/dict-data',
  110. component: Layout,
  111. hidden: true,
  112. children: [
  113. {
  114. path: 'index/:dictId(\\d+)',
  115. component: () => import('@/views/system/dict/data'),
  116. name: 'Data',
  117. meta: { title: '字典数据', activeMenu: '/system/dict' }
  118. }
  119. ]
  120. },
  121. {
  122. path: '/monitor/job-log',
  123. component: Layout,
  124. hidden: true,
  125. children: [
  126. {
  127. path: 'index',
  128. component: () => import('@/views/monitor/job/log'),
  129. name: 'JobLog',
  130. meta: { title: '调度日志', activeMenu: '/monitor/job' }
  131. }
  132. ]
  133. },
  134. {
  135. path: '/tool/gen-edit',
  136. component: Layout,
  137. hidden: true,
  138. children: [
  139. {
  140. path: 'index',
  141. component: () => import('@/views/tool/gen/editTable'),
  142. name: 'GenEdit',
  143. meta: { title: '修改生成配置', activeMenu: '/tool/gen' }
  144. }
  145. ]
  146. }
  147. ];
  148. const router = createRouter({
  149. history: createWebHistory(),
  150. routes: constantRoutes,
  151. scrollBehavior(to, from, savedPosition) {
  152. if (savedPosition) {
  153. return savedPosition
  154. } else {
  155. return { top: 0 }
  156. }
  157. },
  158. });
  159. export default router;