功能:将项目文件自动转为相应的路由配置 和
Nuxt
的路由一样,可实现的功能可以参考这里
将传入的项目目录,自动转为 vue-router 的路由配置,component 使用异步加载
安装:npm i vue-router-auto -s
然后在 src/router/index.js 里面统一处理
import Vue from 'vue'
import Router from 'vue-router'
// 引入依赖
import autoRouter from 'vue-router-auto'
Vue.use(Router)
let routes = autoRouter({
// 页面级的.vue存放位置,必传
rc: require.context('@/views', true, /\.vue$/),
// '/'的重定向,可选,默认为''
redirect: '/test',
// 页面级的.vue存放的文件夹,可选,默认为:views
rootFile: 'views',
})
export default new Router({ routes })
views/
--| login.vue
--| home.vue
--| user/
-----| index.vue
-----| edit.vue
-----| info.vue
[
{
name:'login',
path:'/login',
component: () => import('@/views/login.vue')
},
{
name:'home',
path:'/home',
component: () => import('@/views/home.vue')
},
{
name:'user',
path:'/user',
component: () => import('@/views/user/index.vue')
},
{
name:'user-info',
path:'/user/info',
component: () => import('@/views/user/info.vue')
},
{
name:'user-edit',
path:'/user/edit',
component: () => import('@/views/user/edit.vue')
}
]
创建内嵌子路由,你需要添加一个 Vue 文件,同时添加一个与该文件同名的目录用来存放子视图组件。
views/
--| login.vue
--| home.vue
--| home/
-----| index.vue
-----| about.vue
-----| product.vue
--| user/
-----| index.vue
-----| info.vue
[
{
name:'login',
path:'/login',
component: () => import('@/views/login.vue')
},
{
path:'/home',
component: () => import('@/views/home.vue'),
children:[
{
name:'home-index',
path:'',
component: () => import('@/views/home/index.vue')
},
{
name:'home-about',
path:'about',
component: () => import('@/views/home/about.vue')
},
{
name:'home-product',
path:'product',
component: () => import('@/views/home/product.vue')
}
]
},
{
name:'user',
path:'/user',
component: () => import('@/views/user/index.vue')
},
{
name:'user-info',
path:'/user/info',
component: () => import('@/views/user/info.vue')
}
]
views/
--| login.vue
--| home.vue
--| home/
-----| _id.vue
-----| about.vue
--| user/
-----| user-edit.vue
[
{
name:'login',
path:'/login',
component: () => import('@/views/login.vue')
},
{
name:'home',
path:'/home',
component: () => import('@/views/home.vue'),
children:[
{
name:'home-id',
path:':id',
component: () => import('@/views/home/_id.vue')
},
{
name:'home-about',
path:'about',
component: () => import('@/views/home/about.vue')
}
]
},
{
name:'user-edit',
path:'/user/edit',
component: () => import('@/views/user/user-edit.vue')
}
]