vue自動(dòng)路由-單頁(yè)面項(xiàng)目(非build時(shí)構(gòu)建)
這是一個(gè)什么項(xiàng)目?
答:這是一個(gè)單頁(yè)面的vue.js項(xiàng)目,主要為了實(shí)現(xiàn)在非build時(shí),進(jìn)行自動(dòng)路由。簡(jiǎn)單點(diǎn)說(shuō),就是在請(qǐng)求頁(yè)面時(shí),根據(jù)url進(jìn)行動(dòng)態(tài)添加路由。
自動(dòng)路由有什么限制嗎?
答:有,因?yàn)槭峭ㄟ^(guò)url進(jìn)行動(dòng)態(tài)添加,所以,在指定文件夾下,組件文件的相對(duì)路徑必須與url有一定的關(guān)系。當(dāng)前demo項(xiàng)目,url路徑與modules文件夾下的組件相對(duì)路徑一致。例如:
url地址:localhost:5000/home/index
組件路徑:modules/home/index/index.vue
此方式的自動(dòng)路由能做些什么?
答:
1.動(dòng)態(tài)權(quán)限控制:在匹配不上路由時(shí),請(qǐng)求后臺(tái)獲取是否有權(quán)限,根據(jù)后臺(tái)的反饋處理是否添加路由(是否允許訪問(wèn))。
2.自動(dòng)跳轉(zhuǎn)首頁(yè)、404頁(yè)面等頁(yè)面
項(xiàng)目demo地址
vue.js單項(xiàng)目自動(dòng)路由:https://github.com/bobowire/wireboy.samples/tree/master/vue.js/onepage
具體步驟
1.組件生成
在router文件夾下添加import.js文件,代碼如下圖:
源碼:
module.exports = file => () => import('@/modules/' + file + '.vue')
2.攔截路由
在src目錄下,添加autoroute.js文件,代碼如下圖:
源碼:
import router from './router' const _import = require('./router/import')// 獲取組件的方法 router.beforeEach(async (to, from, next) => { // 默認(rèn)的首頁(yè)頁(yè)面 if (to.fullPath === '/') { next('/home/index') } else if (to.matched.length === 0) { // 獲取組件路徑 let componentpath = to.fullPath.substring(1) + '/' + to.fullPath.substring(to.fullPath.lastIndexOf('/') + 1) // 添加路由 router.addRoutes([{ path: to.fullPath, name: to.fullPath.substring(to.fullPath.lastIndexOf('/') + 1), component: _import(componentpath) }]) // 路由重匹配 next({ ...to, replace: true }) } else { next() } })
總結(jié)
以上所述是小編給大家介紹的vue自動(dòng)路由-單頁(yè)面項(xiàng)目(非build時(shí)構(gòu)建),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
- vue+element使用動(dòng)態(tài)加載路由方式實(shí)現(xiàn)三級(jí)菜單頁(yè)面顯示的操作
- vue自定義標(biāo)簽和單頁(yè)面多路由的實(shí)現(xiàn)代碼
- Vue.js 單頁(yè)面多路由區(qū)域操作的實(shí)例詳解
- vue-router單頁(yè)面路由
- 解決vue-router 嵌套路由沒(méi)反應(yīng)的問(wèn)題
- vue 路由緩存 路由嵌套 路由守衛(wèi) 監(jiān)聽(tīng)物理返回操作
- vue2路由方式--嵌套路由實(shí)現(xiàn)方法分析
- Vue2.0使用嵌套路由實(shí)現(xiàn)頁(yè)面內(nèi)容切換/公用一級(jí)菜單控制頁(yè)面內(nèi)容切換(推薦)
- vue多層嵌套路由實(shí)例分析
- 詳解vue路由篇(動(dòng)態(tài)路由、路由嵌套)
- vue 在單頁(yè)面應(yīng)用里使用二級(jí)套嵌路由
相關(guān)文章
vue離開(kāi)頁(yè)面時(shí)如何銷毀定時(shí)器
這篇文章主要介紹了vue離開(kāi)頁(yè)面時(shí)如何銷毀定時(shí)器,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05基于Vue3實(shí)現(xiàn)前端埋點(diǎn)上報(bào)插件并打包發(fā)布到npm的詳細(xì)過(guò)程
這篇文章主要介紹了基于Vue3實(shí)現(xiàn)一個(gè)前端埋點(diǎn)上報(bào)插件并打包發(fā)布到npm,本項(xiàng)目采用pnpm進(jìn)行Monorepo環(huán)境搭建,因?yàn)槲磥?lái)這個(gè)項(xiàng)目可能會(huì)加入更多的工具包,需要的朋友可以參考下2022-10-10Vue 動(dòng)態(tài)設(shè)置路由參數(shù)的案例分析
這篇文章主要介紹了Vue 動(dòng)態(tài)設(shè)置路由參數(shù)的案例分析,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-04-04vue監(jiān)聽(tīng)鍵盤(pán)事件的相關(guān)總結(jié)
這篇文章主要介紹了vue監(jiān)聽(tīng)鍵盤(pán)事件的相關(guān)總結(jié),幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2021-01-01Vue2.0如何發(fā)布項(xiàng)目實(shí)戰(zhàn)
本篇文章主要介紹了Vue2.0如何發(fā)布項(xiàng)目實(shí)戰(zhàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07