结合 webpack 实现 children 子路由
新建如下目录结构:
我们创建了子路由的各个模块,新建router.js,把子路由模块从main.js中抽离出来
router.js:
import VueRouter from 'vue-router' // 导入 Account 组件 import account from './main/Account.vue' import goodslist from './main/GoodsList.vue' // 导入Account的两个子组件 import login from './subcom/login.vue' import register from './subcom/register.vue' // 3. 创建路由对象 var router = new VueRouter({ routes: [ // account goodslist { path: '/account', component: account, children: [ { path: 'login', component: login }, { path: 'register', component: register } ] }, { path: '/goodslist', component: goodslist } ] }) // 把路由对象暴露出去 export default router
在main.js导入router.js
import Vue from 'vue' // 1. 导入 vue-router 包 import VueRouter from 'vue-router' // 2. 手动安装 VueRouter Vue.use(VueRouter) // 导入 app 组件 import app from './App.vue' // 导入 自定义路由模块 import router from './router.js' var vm = new Vue({ el: '#app', render: c => c(app), // render 会把 el 指定的容器中,所有的内容都清空覆盖,所以 不要 把 路由的 router-view 和 router-link 直接写到 el 所控制的元素中 router // 4. 将路由对象挂载到 vm 上 })