124 lines
3.6 KiB
JavaScript
124 lines
3.6 KiB
JavaScript
import Vue from 'vue'
|
||
import VueRouter from 'vue-router'
|
||
import store from '../store'
|
||
|
||
Vue.use(VueRouter)
|
||
|
||
const routes = [
|
||
{
|
||
path: '/', //页面主路由
|
||
name: 'main',
|
||
component: () => import ('@/views/Main.vue'),
|
||
children: [
|
||
{// 资产库主页
|
||
path: '/workspace',
|
||
name: 'workspace',
|
||
component: () => import('../views/workspace/Workspace')
|
||
},
|
||
{// 用户无任何小组情况下的显示及小组创建
|
||
path: '/cooperationCreate',
|
||
name: 'cooperationCreate',
|
||
component: () => import('../views/cooperation/CooperationCreate')
|
||
},
|
||
{
|
||
path: '/repository',
|
||
name: 'repository',// 模型
|
||
component: () => import('../views/repository/Repository')
|
||
},
|
||
{
|
||
path: '/manage',
|
||
name: '管理中心',
|
||
component: () => import('../views/manage/Manage'),
|
||
children: [
|
||
{
|
||
path: '/workspaceManage',
|
||
name: '资产库管理',
|
||
component: () => import('../views/workspace/WorkspaceManage')
|
||
},
|
||
{
|
||
path: '/cooperationUpdate',
|
||
name: 'PAL小组更新(管理)',
|
||
component: () => import('../views/cooperation/CooperationUpdate')
|
||
},
|
||
{
|
||
path: '/palUser',
|
||
name: 'PAL用户',
|
||
component: () => import('../views/user/User')
|
||
},
|
||
{
|
||
path: '/bpmOrg',
|
||
name: 'BPM组织架构',
|
||
component: () => import('../views/user/BPMOrg')
|
||
},
|
||
{
|
||
path: '/mappingManagement_correlated',
|
||
name: 'mappingManagement_correlated',
|
||
component: () => import('../views/mappingManagement/MappingManagement')
|
||
},
|
||
{
|
||
path: '/mappingManagement_palNotCorrelated',
|
||
name: 'mappingManagement_palNotCorrelated',
|
||
component: () => import('../views/mappingManagement/MappingManagement')
|
||
},
|
||
{
|
||
path: '/mappingManagement_bpmNotCorrelated',
|
||
name: 'mappingManagement_bpmNotCorrelated',
|
||
component: () => import('../views/mappingManagement/MappingManagement')
|
||
},
|
||
{
|
||
path: '/themeStyle',
|
||
component: () => import('../views/portal/ThemeStyle')
|
||
},
|
||
{
|
||
path: '/commonRepository',
|
||
component: () => import('../views/portal/CommonRepository')
|
||
},
|
||
{
|
||
path: '/userGroup',
|
||
component: () => import('../views/portal/UserGroup')
|
||
}
|
||
]
|
||
}
|
||
]
|
||
},
|
||
{
|
||
path: '/devGetSession', //开发时获取session作用
|
||
name: 'devGetSession',
|
||
component: () => import('../views/DevGetSession.vue')
|
||
}
|
||
]
|
||
|
||
const router = new VueRouter({
|
||
routes
|
||
})
|
||
|
||
/**
|
||
*
|
||
* to 表示将要跳转到的组件 (目标组件)
|
||
* console.log(from); //(源组件)
|
||
* next();
|
||
* next 是一个函数
|
||
* next() 进入下一个组件的钩子函数
|
||
* next(false) 阻止跳转 中断导航
|
||
* next("/login") 进入指定的组件的钩子函数
|
||
*/
|
||
// 路由守卫
|
||
router.beforeEach((to, from, next) => {
|
||
if (production === false && store.state.sessionId == null && to.path != "/devGetSession") {
|
||
//进入一个路由获取session,获取session后再进入主入口
|
||
next("/devGetSession");
|
||
} else {
|
||
//跳转前设置title
|
||
//window.document.title = to.meta.title;
|
||
next();
|
||
}
|
||
//to.matched.some(res=>{res.meta.isLogin}) 能够获取路由配置的参数
|
||
|
||
});
|
||
|
||
//跳转后设置scroll为原点
|
||
router.afterEach((to, from, next) => {
|
||
window.scrollTo(0, 0);
|
||
});
|
||
export default router
|