uni-app路由配置文件pages.json平臺化拆分
對uni-app路由配置文件pages.json進行平臺化拆分
背景:公司打造小程序矩陣化,以uni-app作為技術(shù)棧生成不同平臺的小程序代碼。小程序項目包含5個平臺的代碼,雖然是一份代碼運行5個平臺,但是各個平臺又有差異,在代碼里面需要做很多條件編譯進行兼容處理。隨著項目的壯大與頁面的增多,控制路由的pages.json已經(jīng)異常龐大且代碼可讀性差(想找一個頁面需要找到上下文切換,浪費時間并且可能誤刪不同平臺的頁面),亟需優(yōu)化。
例子:
"globalStyle": {
// #ifndef MP-TOUTIAO
"navigationStyle": "custom",
// #endif
// #ifdef MP-TOUTIAO
"navigationStyle": "default",
// #endif
// #ifdef MP-WEIXIN
"backgroundColor": "#F3F5F8",
// #endif
// #ifdef MP-TOUTIAO || MP-BAIDU
"backgroundColor": "#fff",
// #endif
"enablePullDownRefresh": false,
"navigationBarTextStyle": "black",
// #ifndef MP-ALIPAY
"navigationBarTitleText": "XXXX",
// #endif
// #ifdef MP-ALIPAY
"navigationBarTitleText": "XXXXXX",
// #endif
"navigationBarBackgroundColor": "#fff",
// #ifdef MP-WEIXIN
// 華為P40Pro 設(shè)備 key
"qbDebugKey": ["59fc8a158775abbe1fd9809abc887b31"],
// #endif
"backgroundTextStyle": "light"
},
優(yōu)化思路:
將pages.json拆分,共同配置放到pages.json,差異配置新建不同平臺文件維護,構(gòu)建時再進行合并。
過程:
- 翻閱資料與查看uni打包構(gòu)建源碼,在@dcloudio/webpack-uni-pages-loader/lib/index.js與@dcloudio/uni-cli-shared/lib/pages.js中發(fā)現(xiàn),在處理pages.json的過程中會執(zhí)行./src/pages.js,該js需返回全局配置對象(結(jié)構(gòu)與pages.json一致),pages.js要求CommonJS規(guī)范,直接通過module.exports輸出一個鉤子函數(shù),鉤子函數(shù)返回配置對象。所以,我們只需要新建pages.js,然后根據(jù)process.env.UNI_PLATFORM返回不同平臺的路由配置即可
// pages.js關(guān)鍵代碼
const pagesJsonJsFileName = 'pages.js'
function processPagesJson (pagesJson, loader = {
addDependency: function () {}
}) {
const pagesJsonJsPath = path.resolve(process.env.UNI_INPUT_DIR, pagesJsonJsFileName)
if (fs.existsSync(pagesJsonJsPath)) {
delete require.cache[pagesJsonJsPath]
const pagesJsonJsFn = require(pagesJsonJsPath)
if (typeof pagesJsonJsFn === 'function') {
pagesJson = pagesJsonJsFn(pagesJson, loader)
if (!pagesJson) {
console.error(`${pagesJsonJsFileName} ${uniI18n.__('cliShared.requireReturnJsonObject')}`)
}
} else {
console.error(`${pagesJsonJsFileName} ${uniI18n.__('cliShared.requireExportFunction')}`)
}
}
return pagesJson
}
- 新建src/router文件夾 文件夾下新建5個平臺的路由文件。 如下例子(src/router/weixin.js):
module.exports = {
pages: [
{
path: 'pages/index/index',
style: {
enablePullDownRefresh: false,
}
},
// ...
],
subPackages: [
{
root: 'servicePackage',
pages: [
{
path: 'xxx/xxxx/xxxx'
}
]
}
// ...
]
}
新建src/pages.js,根據(jù)process.env.UNI_PLATFORM加載不同配置文件
/**
* 此文件為@dcloudio/webpack-uni-pages-loader的一個鉤子入口,遵循CommonJs規(guī)范
* 源碼路徑:node_modules\@dcloudio\uni-cli-shared\lib\pages.js
*/
const platform = process.env.UNI_PLATFORM.substring(3) // 獲取platform mp-weixin
const path = require('path')
const routerFilePath = path.join(__dirname, `router/${platform}.js`)
const platformPageConfig = require(routerFilePath)
// pagesJson參數(shù)是pages.json值
module.exports = (pagesJson, loader) => {
return {
...platformPageConfig,
...pagesJson
}
}
由于不是webpack的標(biāo)準運行依賴,所以需要手動添加依賴項(使用addDependency),并且需要每次清除模塊的緩存,修改一下src/pages.js代碼
/**
* 此文件為@dcloudio/webpack-uni-pages-loader的一個鉤子入口,遵循CommonJs規(guī)范
* 可以直接使用require引入其他依賴,但是不會有熱重載的效果,需要加上addDependency
*/
const platform = process.env.UNI_PLATFORM.substring(3) // 獲取platform mp-weixin
const path = require('path')
const routerFilePath = path.join(__dirname, `router/${platform}.js`)
const platformPageConfig = require(routerFilePath)
// pagesJson參數(shù)是pages.json值
module.exports = (pagesJson, loader) => {
// 開發(fā)模式下才需要熱重載
if (['test', 'development'].includes(process.env.NODE_ENV)) {
console.warn(`-----${process.env.NODE_ENV}----\n`)
// 動態(tài)添加依賴,告訴webpack改文件需要熱重載
loader.addDependency(require.resolve(routerFilePath))
// 手動清除緩存
delete require.cache[require.resolve(routerFilePath)]
}
return {
...platformPageConfig,
...pagesJson
}
}
大功告成,項目的路由配置一下清晰了許多,由于路由配置文件為js,可以加入代碼進行條件化判斷生成的路由。如果只需要生成一個平臺的代碼,也可以在此基礎(chǔ)上對路由進行模塊化。
參考文章 http://www.dbjr.com.cn/article/272944.htm
以上就是uni-app路由配置文件pages.json平臺化拆分的詳細內(nèi)容,更多關(guān)于uni-app路由配置pages.json的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JavaScript Math對象和調(diào)試程序的方法分析
這篇文章主要介紹了JavaScript Math對象和調(diào)試程序的方法,結(jié)合實例形式分析了javascript中Math對象生成隨機數(shù)以及使用alert()、console.log()函數(shù)進行錯誤調(diào)試相關(guān)操作技巧,需要的朋友可以參考下2019-05-05
前端使用JavaScript結(jié)合CSS實現(xiàn)3D旋轉(zhuǎn)跟隨鼠標(biāo)變化
這篇文章主要介紹了前端使用JavaScript結(jié)合CSS實現(xiàn)3D旋轉(zhuǎn)跟隨鼠標(biāo)變化,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-01-01
用javascript對一個json數(shù)組深度賦值示例
本節(jié)主要介紹了用javascript對一個json數(shù)組深度賦值的具體實現(xiàn),需要的朋友可以參考下2014-07-07
簡單聊聊JavaScript中作用域與自執(zhí)行函數(shù)的使用
作用域指的是一個變量的作用范圍,自執(zhí)行函數(shù)是指定義后立即執(zhí)行的函數(shù),它可以被用來創(chuàng)建一個私有作用域,本文主要來和大家聊聊二者的具體定義與使用,感興趣的可以了解下2024-03-03
網(wǎng)站發(fā)布后Bootstrap框架引用woff字體無法正常顯示的解決方法
這篇文章主要介紹了網(wǎng)站發(fā)布到IIS后Bootstrap框架引用的woff字體無法正常顯示的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11

