vue使用require.context實現(xiàn)動態(tài)注冊路由
需求場景:
在日常的功能練習和調(diào)試過程中,需要一個demo項目進行功能測試,由于頻繁.vue頁面的同時,又要再router.js文件里面注冊路由,感覺有點無聊和枯燥。基于此出發(fā)點,考慮能否自動讀取文件夾下的文件進行路由注冊。
借鑒思路:
參考vue的功能基礎組件的自動化全局注冊,看到一個require.context方法,可以讀取某個文件夾下的文件信息。因此考慮,使用這個方法,獲取views文件夾下的.vue頁面,文件夾名稱作為路由名稱
require.context的使用介紹:
一個webpack的api,通過執(zhí)行require.context函數(shù)獲取一個特定的上下文,主要用來實現(xiàn)自動化導入模塊,在前端工程中,如果遇到從一個文件夾引入很多模塊的情況,可以使用這個api,它會遍歷文件夾中的指定文件,然后自動導入,使得不需要每次顯式的調(diào)用import導入模塊
頁面代碼:
如下圖示,views文件夾下的內(nèi)容,都需要進行路由注冊。
文件的路徑有2種,(1)簡單的vue功能頁面,直接掛在views文件夾下;(2)復雜的頁面,在views下在新建文件夾進行處理。
目前需要自動注冊的路由頁面,是針對“直接掛在views文件夾”下的頁面。(因為views下的二級頁面,暫時沒有想到好的方案)

router/index.js頁面代碼
心路歷程:
(1)一開始的想法,是想著用數(shù)組對象的方式定義好,路由名稱和引入的路徑地址,但是覺得還是不夠自動化,新建.vue文件的時候還是需要手動添加;
(2)后來想到用使用require.context方法得到fileName,然后根據(jù)字符串裁減和拼接,得到我所需的url和文件相對路徑;
例如: component: () =>import(【變量】),但是后來發(fā)現(xiàn),import()里面,不能使用變量!!!!!!!!!
原因:根據(jù)es6module語法,由于import是靜態(tài)執(zhí)行,所以不能使用表達式和變量這些只有在運行時才能得到結果的語法結構。
(3)由由于import的使用限制,不能動態(tài)使用() =>import的語法,因此在考慮,能否直接替換掉這種異步加載引入的寫法。經(jīng)過分析,得出pathConfig字段里面有一個屬性的內(nèi)容,是指定的vue頁面的default模塊內(nèi)容。經(jīng)測試,可以使用。
pathConfig的打印內(nèi)容如下示:

(4)因此“views”文件夾下的".vue"文件,引入成功,并用變量routerAry存儲起來,使用concat方法把其他需要手動注冊的路由信息,連接起來,進行路由注冊。
import Vue from 'vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)
// 查詢指定文件夾下的vue頁面,自動注冊路由
// 僅適用于:一個文件夾下的多個路由頁面。用于簡單的頁面的注冊
// pathConfig.default的內(nèi)容,是指定的vue頁面的default模塊內(nèi)容,等同于: () => import('xxxx')
const contextInfo = require.context('../views', false, /.vue$/);
let routerAry = []
contextInfo.keys().forEach(fileName => {
const pathConfig = contextInfo(fileName)
let path = "/" + fileName.substring(2,fileName.length-4)
routerAry.push({
path,
component: pathConfig.default
})
})
const routerList = [
{
path: "/",
redirect: "/animate",
},
{
path: "/openlayers",
component: () => import('../views/openlayers/openlayers')
},{
path: "/render",
component: () => import('../views/render/render')
},{
path: '/vuex',
component: () => import('../views/vuex/vuex')
},{
path: "/echarts",
component: () => import('../views/echarts/echarts')
},{
path: "/ztree",
component: () => import('../views/ztree/ztree')
},{
path: "/ocxplayer",
component: () => import('../views/ocxplayer/ocxplayer')
},{
path: "/animation",
component: () => import('../views/animation/animation')
},
]
const newRouterAry = routerList.concat(routerAry)
const router = new VueRouter({
routes: newRouterAry
})
export default router
以上就是vue使用require.context實現(xiàn)動態(tài)注冊路由的詳細內(nèi)容,更多關于vue 動態(tài)注冊路由的資料請關注腳本之家其它相關文章!
相關文章
Vue.js仿Metronic高級表格(二)數(shù)據(jù)渲染
這篇文章主要為大家詳細介紹了Vue.js仿Metronic高級表格的數(shù)據(jù)渲染,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04
Vue2.0用 watch 觀察 prop 變化(不觸發(fā))
本篇文章主要介紹了Vue2.0用 watch 觀察 prop 變化(不觸發(fā)),非常具有實用價值,需要的朋友可以參考下2017-09-09
vue+element-ui監(jiān)聽滾動實現(xiàn)錨點定位方式(雙向),錨點問題
這篇文章主要介紹了vue+element-ui監(jiān)聽滾動實現(xiàn)錨點定位方式(雙向),錨點問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
vue.js數(shù)據(jù)綁定的方法(單向、雙向和一次性綁定)
本篇文章主要介紹了vue.js數(shù)據(jù)綁定的方法(單向、雙向和一次性綁定),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07

