詳解vue-cli3多頁(yè)應(yīng)用改造
需求
一個(gè)平臺(tái)P,包含產(chǎn)品a、b、c、d、e。各產(chǎn)品UI樣式風(fēng)格統(tǒng)一,且會(huì)用到公共配置(HOST、是否添加埋點(diǎn)js)、組件(頭部導(dǎo)航、表格、搜索框)、方法(請(qǐng)求攔截、生成UUID)。
現(xiàn)狀:由于歷史遺留原因,各產(chǎn)品為獨(dú)立SPA、各自維護(hù),配置、組件也都自成一體,只是大概樣式上保持了一致,但細(xì)節(jié)(比如同一面包屑樣式,左邊距5px、8px都有)都不一致。
這種情況下,改組件、改配置都得一改改多個(gè)地方,且有些項(xiàng)目是vue-cli2、有些是vue-cli3,項(xiàng)目間依賴包的版本也不一致,維護(hù)起來(lái)非常不友好。
目標(biāo):整合各產(chǎn)品單頁(yè)應(yīng)用為MPA,提取公共文件(主題、配置、組件、方法),減少規(guī)范性東西的維護(hù)成本。
目錄結(jié)構(gòu)對(duì)比
整合前
bds-bank-fe │ README.md │ │// 靜態(tài)資源輸出目錄 │ └───dist │ └───index.html + static // 平臺(tái)首頁(yè) │ └───label // 產(chǎn)品a │ │ └───index.html + static │ └───metrics // 產(chǎn)品b │ └───service // 產(chǎn)品c │ └───help // 產(chǎn)品d │ │// 項(xiàng)目路徑 │ └───help-center // 產(chǎn)品d └───portal-page // 平臺(tái)首頁(yè) └───service-doc // 產(chǎn)品c └───unify-label // 產(chǎn)品a └───unify-metrics // 產(chǎn)品b │ └───build │ └───config │ └───src
整合后
│// 靜態(tài)資源輸出目錄 │ └───dist │ └───index.html │ └───label.html │ └───metric.html │ └───service.html │ └───stocktake.html │ └───css │ └───js │ └───img ├── public │ └───favicon.ico │ └───index.html │ │// 項(xiàng)目路徑 │ ├── src │ └── assets │ └── components │ ├── pages │ ├── index │ ├── label │ ├── metric │ ├── service │ ├── stocktake
實(shí)現(xiàn)
vue-cli 3.0官方支持多頁(yè),重點(diǎn)在于vue.config.js文件中pages這個(gè)配置項(xiàng),每個(gè)頁(yè)面單獨(dú)配置entry、template、filename等。pages配置說(shuō)明
// 官網(wǎng)示例如下 module.exports = { pages: { index: { // page 的入口 entry: 'src/index/main.js', // 模板來(lái)源 template: 'public/index.html', // 在 dist/index.html 的輸出 filename: 'index.html', // 當(dāng)使用 title 選項(xiàng)時(shí), // template 中的 title 標(biāo)簽需要是 <title><%= htmlWebpackPlugin.options.title %></title> title: 'Index Page', // 在這個(gè)頁(yè)面中包含的塊,默認(rèn)情況下會(huì)包含 // 提取出來(lái)的通用 chunk 和 vendor chunk。 chunks: ['chunk-vendors', 'chunk-common', 'index'] }, // 當(dāng)使用只有入口的字符串格式時(shí), // 模板會(huì)被推導(dǎo)為 `public/subpage.html` // 并且如果找不到的話,就回退到 `public/index.html`。 // 輸出文件名會(huì)被推導(dǎo)為 `subpage.html`。 subpage: 'src/subpage/main.js' } }
Step1: 創(chuàng)建新項(xiàng)目
選擇需要的Babel、Router、Vuex、eslint...
具體步驟參考官網(wǎng):創(chuàng)建一個(gè)項(xiàng)目
Step2: 修改配置文件vue.config.js
在根目錄下新建public文件夾,包含favicon.ico和index.html兩個(gè)文件。
index文件內(nèi)容如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width,initial-scale=1.0"> <link rel="icon" href="<%= BASE_URL %>favicon.ico" rel="external nofollow" > <title>P-公共服務(wù)平臺(tái)</title> </head> <body> <noscript> <strong> We're sorry but page doesn't work properly without JavaScript enabled. Please enable it to continue. </strong> </noscript> <div id="app"></div> <!-- built files will be auto injected --> </body> </html>
然后,在根目錄下新建vue.config.js
const glob = require('glob') const path = require('path') const resolve = (dir) => path.join(__dirname, dir) const PAGES_PATH = './src/pages/*/*.js' module.exports = { pages: setPages(), // TODO:以下內(nèi)容非生成多頁(yè)應(yīng)用必須配置 lintOnSave: true, productionSourceMap: false, chainWebpack: config => { /** * 自動(dòng)化導(dǎo)入文件 */ const types = ['vue-modules', 'vue', 'normal-modules', 'normal'] types.forEach( type => addStyleResource(config.module.rule('less').oneOf(type))) /** * 添加別名 */ config.resolve.alias .set('@index', resolve('src/pages/index')) .set('@label', resolve('src/pages/label')) .set('@metrics', resolve('src/pages/metric')) .set('@service', resolve('src/pages/service')) .set('@stocktake', resolve('src/pages/stocktake')) /** * 菜單icon處理為svg-sprite */ config.module .rule('svg') .exclude .add(resolve('src/assets/icons/menus')) .end() config.module .rule('svg-sprite-loader') .test(/\.svg$/) .include .add(resolve('src/assets/icons/menus')) // 處理目錄 .end() .use('svg-sprite-loader') .loader('svg-sprite-loader') .options({ symbolId: 'icon-[name]' }) } } /** * 組裝頁(yè)面 */ function setPages () { let pages = {} glob.sync(PAGES_PATH).forEach(filepath => { let fileList = filepath.split('/') let fileName = fileList[fileList.length - 2] pages[fileName] = { entry: filepath, template: 'public/index.html', filename: `${fileName}.html`, // title: chunks: ['chunk-vendors', 'chunk-common', fileName] } }) return pages } /** * 注入公共less * @param rule */ function addStyleResource (rule) { rule.use('style-resource') .loader('style-resources-loader') .options({ patterns: [ path.resolve(__dirname, 'src/assets/styles/variable.less') ] }) }
Step3: 拷貝原項(xiàng)目src目錄至pages下,大概長(zhǎng)這樣
Step4: 各產(chǎn)品原項(xiàng)目下package.json依賴包都挪到根目錄下package.json,重新安裝
PS:由于依賴向上升級(jí),某些老版本依賴包可能會(huì)存在升級(jí)引發(fā)的問(wèn)題,需要細(xì)心走查一遍。這里由于業(yè)務(wù)不一樣,就不詳細(xì)贅述了
然后npm start,完美啟動(dòng)~
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue 單頁(yè)應(yīng)用和多頁(yè)應(yīng)用的優(yōu)劣
- vue-cli單頁(yè)應(yīng)用改成多頁(yè)應(yīng)用配置詳解
- webpack4.0+vue2.0利用批處理生成前端單頁(yè)或多頁(yè)應(yīng)用的方法
- Vue CLI3基礎(chǔ)學(xué)習(xí)之pages構(gòu)建多頁(yè)應(yīng)用
- 詳解Vue CLI3 多頁(yè)應(yīng)用實(shí)踐和源碼設(shè)計(jì)
- 手把手教你vue-cli單頁(yè)到多頁(yè)應(yīng)用的方法
- Vue單頁(yè)及多頁(yè)應(yīng)用全局配置404頁(yè)面實(shí)踐記錄
- 詳解如何使用 vue-cli 開(kāi)發(fā)多頁(yè)應(yīng)用
- vue 如何從單頁(yè)應(yīng)用改造成多頁(yè)應(yīng)用
相關(guān)文章
Vue 中頁(yè)面?zhèn)髦档亩喾N方式小結(jié)
本文主要介紹了Vue 中頁(yè)面?zhèn)髦档亩喾N方式小結(jié),主要包括路由傳參、Vuex 狀態(tài)管理、Props 屬性和事件傳遞數(shù)據(jù)這幾種,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10vue項(xiàng)目打包解決靜態(tài)資源無(wú)法加載和路由加載無(wú)效(404)問(wèn)題
這篇文章主要介紹了vue項(xiàng)目打包,解決靜態(tài)資源無(wú)法加載和路由加載無(wú)效(404)問(wèn)題,靜態(tài)資源無(wú)法使用,那就說(shuō)明項(xiàng)目打包后,圖片和其他靜態(tài)資源文件相對(duì)路徑不對(duì),本文給大家介紹的非常詳細(xì),需要的朋友跟隨小編一起看看吧2023-10-10Vue2.0基于vue-cli+webpack父子組件通信(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇Vue2.0基于vue-cli+webpack父子組件通信(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09解決vue的component標(biāo)簽渲染問(wèn)題
這篇文章主要介紹了解決vue的component標(biāo)簽渲染問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03基于element-ui中el-select下拉框選項(xiàng)過(guò)多的優(yōu)化方案
這篇文章主要介紹了基于element-ui中el-select下拉框選項(xiàng)過(guò)多的優(yōu)化方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04VUE 實(shí)現(xiàn)element upload上傳圖片到阿里云
這篇文章主要介紹了VUE 實(shí)現(xiàn)element upload上傳圖片到阿里云,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08vue設(shè)置全局變量5種方法(讓你的數(shù)據(jù)無(wú)處不在)
這篇文章主要給大家介紹了關(guān)于vue設(shè)置全局變量的5種方法,通過(guò)設(shè)置的方法可以讓你的數(shù)據(jù)無(wú)處不在,在項(xiàng)目中經(jīng)常會(huì)復(fù)用一些變量和函數(shù),比如用戶的登錄token,用戶信息等,這時(shí)將它們?cè)O(shè)為全局的就顯得很重要了,需要的朋友可以參考下2023-11-11