#搭建Vue+TypeScript項(xiàng)目(四)

vue-router的使用

模塊化路由

1.在src文件夾下新建router文件夾,新建router.ts(包含路由攔截器)

import Vue from 'vue';
import Router from 'vue-router';
import store from '@/store';
import login from '@/router/login/index';
import home from '@/router/home/index';

Vue.use(Router);

const router = new Router({
  mode: 'history',
  routes: [...home, ...login]
});
// 導(dǎo)航守衛(wèi)(路由攔截)
router.beforeEach((to, from, next) => {
  
  // 如果沒登錄,就跳到登錄頁
  const isLogin: boolean = store.getters.isLogin;
  if (isLogin) {
    next();
  } else {
    if ('/login'.indexOf(to.path) !== -1) {
      next();
    } else {
      next(`/login`);
    }
  }
});
export default router;

2.在src/router文件夾下建login文件夾,新建login.ts(登錄路由模塊)

export default [
  {
    path: '/login',
    name: 'login',
    component: () => import(/* webpackChunkName: "login" */ '@/views/Login.vue')
  }
];

2.在src/router文件夾下建home文件夾,新建home.ts(主路由模塊)

import Home from '@/App.vue';

export default [
  {
    path: '/',
    name: 'home',
    component: Home,
    redirect: '/page1',
    children: [
      {
        path: '/page1',
        name: 'page1',
        // route level code-splitting
        // this generates a separate chunk (about.[hash].js) for this route
        // which is lazy-loaded when the route is visited.
        component: () =>
          import(/* webpackChunkName: "login" */ '@/views/home/Page1.vue')
      },
      {
        path: '/page2',
        name: 'page2',
        // route level code-splitting
        // this generates a separate chunk (about.[hash].js) for this route
        // which is lazy-loaded when the route is visited.
        component: () =>
          import(/* webpackChunkName: "login" */ '@/views/home/Page2.vue')
      }
    ]
  }
];
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容