index.js 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. import Vue from 'vue';
  2. import Router from 'vue-router';
  3. Vue.use(Router);
  4. /* Layout */
  5. import Layout from '@/layout';
  6. import LargeScreen from '@/views/largeScreen/index.vue'
  7. /**
  8. * Note: 路由配置项
  9. *
  10. * hidden: true // 当设置 true 的时候该路由不会再侧边栏出现 如401,login等页面,或者如一些编辑页面/edit/1
  11. * alwaysShow: true // 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式--如组件页面
  12. * // 只有一个时,会将那个子路由当做根路由显示在侧边栏--如引导页面
  13. * // 若你想不管路由下面的 children 声明的个数都显示你的根路由
  14. * // 你可以设置 alwaysShow: true,这样它就会忽略之前定义的规则,一直显示根路由
  15. * redirect: noRedirect // 当设置 noRedirect 的时候该路由在面包屑导航中不可被点击
  16. * name:'router-name' // 设定路由的名字,一定要填写不然使用<keep-alive>时会出现各种问题
  17. * query: '{"id": 1, "name": "ry"}' // 访问路由的默认传递参数
  18. * roles: ['admin', 'common'] // 访问路由的角色权限
  19. * permissions: ['a:a:a', 'b:b:b'] // 访问路由的菜单权限
  20. * meta : {
  21. noCache: true // 如果设置为true,则不会被 <keep-alive> 缓存(默认 false)
  22. title: 'title' // 设置该路由在侧边栏和面包屑中展示的名字
  23. icon: 'svg-name' // 设置该路由的图标,对应路径src/assets/icons/svg
  24. breadcrumb: false // 如果设置为false,则不会在breadcrumb面包屑中显示
  25. activeMenu: '/system/user' // 当路由设置了该属性,则会高亮相对应的侧边栏。
  26. }
  27. */
  28. // 公共路由
  29. export const constantRoutes = [
  30. {
  31. path: '/redirect',
  32. component: Layout,
  33. hidden: true,
  34. children: [
  35. {
  36. path: '/redirect/:path(.*)',
  37. component: () => import('@/views/redirect')
  38. }
  39. ]
  40. },
  41. {
  42. path: '/login',
  43. component: () => import('@/views/login'),
  44. hidden: true
  45. },
  46. {
  47. path: '/register',
  48. component: () => import('@/views/register'),
  49. hidden: true
  50. },
  51. {
  52. path: '/404',
  53. component: () => import('@/views/error/404'),
  54. hidden: true
  55. },
  56. {
  57. path: '/401',
  58. component: () => import('@/views/error/401'),
  59. hidden: true
  60. },
  61. //智慧园区管理平台
  62. {
  63. path: '/largeScreen',
  64. name: 'largeScreen',
  65. redirect: { name: 'home' },
  66. component: LargeScreen,
  67. hidden: true,
  68. children: [
  69. {
  70. path: 'home',
  71. name: 'home',
  72. meta: {
  73. title: '首页'
  74. },
  75. components: {
  76. default:() => import('@/views/largeScreen/center.vue'),
  77. left: () => import('@/views/largeScreen/home/left.vue'),
  78. right: () => import('@/views/largeScreen/home/right.vue')
  79. }
  80. },
  81. {
  82. path: 'source',
  83. name: 'source',
  84. meta: {
  85. title: '源'
  86. },
  87. components: {
  88. default:() => import('@/views/largeScreen/center.vue'),
  89. left: () => import('@/views/largeScreen/source/left.vue'),
  90. right: () => import('@/views/largeScreen/source/right.vue')
  91. }
  92. },
  93. {
  94. path: 'storage',
  95. name: 'storage',
  96. meta: {
  97. title: '储'
  98. },
  99. components: {
  100. default:() => import('@/views/largeScreen/center.vue'),
  101. left: () => import('@/views/largeScreen/storage/left.vue'),
  102. right: () => import('@/views/largeScreen/storage/right.vue')
  103. }
  104. },
  105. {
  106. path: 'soc',
  107. name: 'soc',
  108. meta: {
  109. title: '荷'
  110. },
  111. components: {
  112. default:() => import('@/views/largeScreen/center.vue'),
  113. left: () => import('@/views/largeScreen/soc/left.vue'),
  114. right: () => import('@/views/largeScreen/soc/right.vue')
  115. }
  116. },
  117. {
  118. path: 'net',
  119. name: 'net',
  120. meta: {
  121. title: '网'
  122. },
  123. components: {
  124. default:() => import('@/views/largeScreen/center.vue'),
  125. left: () => import('@/views/largeScreen/net/left.vue'),
  126. right: () => import('@/views/largeScreen/net/right.vue')
  127. }
  128. },
  129. {
  130. path: 'device',
  131. name: 'device',
  132. meta: {
  133. title: '设备'
  134. },
  135. components: {
  136. default:() => import('@/views/largeScreen/center.vue'),
  137. left: () => import('@/views/largeScreen/device/left.vue'),
  138. right: () => import('@/views/largeScreen/device/right.vue')
  139. }
  140. }
  141. ]
  142. },
  143. {
  144. path: '',
  145. component: Layout,
  146. redirect: 'index',
  147. children: [
  148. {
  149. path: 'index',
  150. component: () => import('@/views/index'),
  151. name: 'Index',
  152. meta: { title: '首页', icon: 'dashboard', affix: true }
  153. }
  154. ]
  155. },
  156. {
  157. path: '/user',
  158. component: Layout,
  159. hidden: true,
  160. redirect: 'noredirect',
  161. children: [
  162. {
  163. path: 'profile',
  164. component: () => import('@/views/system/user/profile/index'),
  165. name: 'Profile',
  166. meta: { title: '个人中心', icon: 'user' }
  167. }
  168. ]
  169. }
  170. ];
  171. // 动态路由,基于用户权限动态去加载
  172. export const dynamicRoutes = [
  173. {
  174. path: '/system/user-auth',
  175. component: Layout,
  176. hidden: true,
  177. permissions: ['system:user:edit'],
  178. children: [
  179. {
  180. path: 'role/:userId(\\d+)',
  181. component: () => import('@/views/system/user/authRole'),
  182. name: 'AuthRole',
  183. meta: { title: '分配角色', activeMenu: '/system/user' }
  184. }
  185. ]
  186. },
  187. {
  188. path: '/system/role-auth',
  189. component: Layout,
  190. hidden: true,
  191. permissions: ['system:role:edit'],
  192. children: [
  193. {
  194. path: 'user/:roleId(\\d+)',
  195. component: () => import('@/views/system/role/authUser'),
  196. name: 'AuthUser',
  197. meta: { title: '分配用户', activeMenu: '/system/role' }
  198. }
  199. ]
  200. },
  201. {
  202. path: '/system/dict-data',
  203. component: Layout,
  204. hidden: true,
  205. permissions: ['system:dict:list'],
  206. children: [
  207. {
  208. path: 'index/:dictId(\\d+)',
  209. component: () => import('@/views/system/dict/data'),
  210. name: 'Data',
  211. meta: { title: '字典数据', activeMenu: '/system/dict' }
  212. }
  213. ]
  214. },
  215. {
  216. path: '/monitor/job-log',
  217. component: Layout,
  218. hidden: true,
  219. permissions: ['monitor:job:list'],
  220. children: [
  221. {
  222. path: 'index/:jobId(\\d+)',
  223. component: () => import('@/views/monitor/job/log'),
  224. name: 'JobLog',
  225. meta: { title: '调度日志', activeMenu: '/monitor/job' }
  226. }
  227. ]
  228. },
  229. {
  230. path: '/tool/gen-edit',
  231. component: Layout,
  232. hidden: true,
  233. permissions: ['tool:gen:edit'],
  234. children: [
  235. {
  236. path: 'index/:tableId(\\d+)',
  237. component: () => import('@/views/tool/gen/editTable'),
  238. name: 'GenEdit',
  239. meta: { title: '修改生成配置', activeMenu: '/tool/gen' }
  240. }
  241. ]
  242. }
  243. ];
  244. // 防止连续点击多次路由报错
  245. let routerPush = Router.prototype.push;
  246. let routerReplace = Router.prototype.replace;
  247. // push
  248. Router.prototype.push = function push(location) {
  249. return routerPush.call(this, location).catch(err => err);
  250. };
  251. // replace
  252. Router.prototype.replace = function push(location) {
  253. return routerReplace.call(this, location).catch(err => err);
  254. };
  255. export default new Router({
  256. mode: 'history', // 去掉url中的#
  257. scrollBehavior: () => ({ y: 0 }),
  258. routes: constantRoutes
  259. });