国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

vue自動路由-單頁面項目(非build時構建)

2024-05-06 15:39:59
字體:
來源:轉載
供稿:網友

這是一個什么項目?

答:這是一個單頁面的vue.js項目,主要為了實現在非build時,進行自動路由。簡單點說,就是在請求頁面時,根據url進行動態添加路由。

自動路由有什么限制嗎?

答:有,因為是通過url進行動態添加,所以,在指定文件夾下,組件文件的相對路徑必須與url有一定的關系。當前demo項目,url路徑與modules文件夾下的組件相對路徑一致。例如:

url地址:localhost:5000/home/index

組件路徑:modules/home/index/index.vue

此方式的自動路由能做些什么?

答:

1.動態權限控制:在匹配不上路由時,請求后臺獲取是否有權限,根據后臺的反饋處理是否添加路由(是否允許訪問)。

2.自動跳轉首頁、404頁面等頁面

項目demo地址

vue.js單項目自動路由: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) => { // 默認的首頁頁面 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() }}) 

總結

以上所述是小編給大家介紹的vue自動路由-單頁面項目(非build時構建),希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 百色市| 高陵县| 保靖县| 义马市| 鹿泉市| 奇台县| 黔江区| 齐齐哈尔市| 司法| 平果县| 晴隆县| 高淳县| 南平市| 淮滨县| 方城县| 娄烦县| 漾濞| 茌平县| 凤阳县| 临西县| 济南市| 哈巴河县| 巫山县| 通河县| 平阳县| 南昌县| 合山市| 雅江县| 侯马市| 临城县| 靖边县| 买车| 布尔津县| 天气| 漳州市| 平塘县| 江都市| 嘉祥县| 嘉兴市| 定兴县| 收藏|