Vue項目分包打包配置(包含dev)完整過程
前言
今天領導要求支援某項目的分包配置,emmm,在參考了公司其他項目的分包操作后,依葫蘆畫瓢,中間也踩了好幾個坑,簡單記錄下過程。
一、拉代碼、安裝依賴
哈哈哈,上來就踩坑了,我拉了代碼后,直接哐哐整,然后一堆依賴報錯,我才發(fā)現(xiàn),同事新增了依賴包,我并不知道,然后就乖乖安裝依賴吧。此處要特別強調一下,***沒有cross-env 這個依賴的,記得要安裝一下,沒有cross-env 這個依賴的,記得要安裝一下,沒有cross-env 這個依賴的,記得要安裝一下,***重要的事情說三遍,不安的話分包整不了。shell命令貼上了:npm install --save-dev cross-env 安裝成功后 package.json里面會多"cross-env": “^7.0.3”,配置項,那就對了.如果實在不行,要不然你就試試全局安裝吧,npm install -g cross-env,反正全局安裝肯定是可以的,
二、配置環(huán)境變量
這個也是個坑坑啊,我要改的項目沒有配置環(huán)境變量,我一開始沒發(fā)現(xiàn),后來死活不加載不同環(huán)境下對應的路由,才發(fā)現(xiàn)是這的坑。還有打包目錄名字可配可不配,不過建議配置上。
vue.config.js中如下配置
let projectName = process.env.PROJECT_NAME || "All"; //獲取名稱 module.exports = { publicPath: './', outputDir: "dist/" + projectName + "/", //打包后的項目目錄名稱,建議這樣修改 productionSourceMap: false, lintOnSave: false, devServer: { //自己公司項目自己配置哈 }, chainWebpack: config => { // 設置環(huán)境變量 config.plugin("define").tap(args => { args[0]["process.env"].PROJECT_NAME = JSON.stringify( process.env.PROJECT_NAME ); return args; }); } }
三、拆路由
把項目中router.js中的要分包的路由分別拆到不同的文件中,例如我圖中就拆了前后9個,后續(xù)不同的打包命令,就會加載這九個文件中的對應的路由。此處有個疑問,就是能不能拆分子路由的問題,大家可以試試。我是把一個模塊的父子路由打包帶走的。此處就放兩個文件路由大家參考一下
//sign.js export default[ { path: "/main", name: "main", meta: { cachePage: true }, component: () => import("@/views/main/main.vue"), children: [ { path: "/other", name: "other", component: () => import("@/views/login/other"), }, /* 貸款簽約 */ { path: "/loanSigning", name: "loanSigning", meta: { cachePage: true, showMain: true }, component: () => import("@/views/loanSigning/index"), }, { path: "/loanSigningEdit", name: "loanSigningEdit", meta: { showBack: true }, component: () => import("@/views/loanSigning/loanSigningEdit"), }, { path: "/loanSigningRead", name: "loanSigningRead", meta: { showBack: true }, component: () => import("@/views/loanSigning/loanSigningRead"), }, ] } ] ```javascript ```javascript //track.js export default[ { path: "/main", name: "main", meta: { cachePage: true }, component: () => import("@/views/main/main.vue"), children: [ { path: "/other", name: "other", component: () => import("@/views/login/other"), }, /* 軌跡視圖 */ { path: "/trackView", name: "mobileMarketing", meta: { cachePage: true, showMain: true }, component: () => import("@/views/trackView/index"), }, { path: "/trackViewAdd", name: "trackViewAdd", meta: { showBack: true }, component: () => import("@/views/trackView/trackViewAdd"), }, ] } ]
四、配置config.js文件
config.js主要是判斷不同的環(huán)境下,加載剛才拆的那九個不同的路由
//config.js let options={ "routersName":[],//路由文件名列表 "menuFlag":"",//顯示的功能列表標識 } if(process.env.PROJECT_NAME=='All'){ options.menuFlag="All" options.routersName=[ ...require("@/plugins/vueRouter/all.js").default ] }else if(process.env.PROJECT_NAME=='potential'){ options.menuFlag="potential" options.routersName=[ ...require("@/plugins/vueRouter/potential.js").default, ] }else if(process.env.PROJECT_NAME=='mobile'){ options.menuFlag="mobile" options.routersName=[ ...require("@/plugins/vueRouter/mobile.js").default, ] }else if(process.env.PROJECT_NAME == 'credit'){ options.menuFlag="credit" options.routersName=[ ...require("@/plugins/vueRouter/credit.js").default, ] }else if(process.env.PROJECT_NAME == 'loan'){ options.menuFlag="loan" options.routersName=[ ...require("@/plugins/vueRouter/loan.js").default, ] }else if(process.env.PROJECT_NAME == 'sign'){ options.menuFlag="sign" options.routersName=[ ...require("@/plugins/vueRouter/sign.js").default, ] }else if(process.env.PROJECT_NAME == 'track'){ options.menuFlag="track" options.routersName=[ ...require("@/plugins/vueRouter/track.js").default, ] }else if(process.env.PROJECT_NAME == 'approval'){ options.menuFlag="approval" options.routersName=[ ...require("@/plugins/vueRouter/approval.js").default, ] }else if(process.env.PROJECT_NAME == 'main'){ options.menuFlag="main" options.routersName=[ ...require("@/plugins/vueRouter/main.js").default, ] } export default options
五、修改router.js
//router.js import Vue from "vue"; import VueRouter from "vue-router"; import store from "@/plugins/vuex/store"; import config from "../../config" //這個路徑要以你的項目路徑來哈,自行修改 Vue.use(VueRouter); let routes=[ { path: "/", name: "index", redirect: "/login" }, { path: "/login", name: "login", meta: { cachePage: true }, component: () => import("@/views/login/login.vue"), } //要拆包的那些路徑,都要刪了哈,不然分包就分個寂寞啦!?。。。。。。? ] routes=[...routes,...config.routersName] //路由表合并 console.log(routes,'routerjs中本身的路由') console.log(config,'config中獲取的路由') console.log(process.env.PROJECT_NAME,'環(huán)境變量') const router = new VueRouter({ // mode: 'hash', base: process.env.BASE_URL, routes }); //如果你的項目中有其他的邏輯 再自行添加哈 // ...........其他業(yè)務邏輯代碼
在合并路由表那塊 ,我本來想試試子路由單獨拿出來,父路由還放在router.js中的,但是我感覺往children里面塞,也不夠優(yōu)雅,就索性把 path: "/main"這個父路由和children里的子路由都拆走了
六、配置package.json
終于到了這一步,臨門一腳了,這一步就是配置shell命令了
為了方便復制,我把package.json里scripts里面的命令代碼給大家貼出來,其他的配置應該不用我貼了吧
//package.json中的命令 "scripts": { "dev": "set NODE_OPTIONS=--openssl-legacy-provider && cross-env PROJECT_NAME=All vue-cli-service serve", "dev:main": "cross-env PROJECT_NAME=main vue-cli-service serve", "dev:potential": "cross-env PROJECT_NAME=potential vue-cli-service serve", "dev:mobile": "cross-env PROJECT_NAME=mobile vue-cli-service serve", "dev:credit": "cross-env PROJECT_NAME=credit vue-cli-service serve", "dev:loan": "cross-env PROJECT_NAME=loan vue-cli-service serve", "dev:sign": "cross-env PROJECT_NAME=sign vue-cli-service serve", "dev:track": "cross-env PROJECT_NAME=track vue-cli-service serve", "dev:approval": "cross-env PROJECT_NAME=approval vue-cli-service serve", "build": "cross-env PROJECT_NAME=All vue-cli-service build", "build:potential": "cross-env PROJECT_NAME=potential vue-cli-service build", "build:main": "cross-env PROJECT_NAME=main vue-cli-service build", "build:mobile": "cross-env PROJECT_NAME=mobile vue-cli-service build", "build:credit": "cross-env PROJECT_NAME=credit vue-cli-service build", "build:loan": "cross-env PROJECT_NAME=loan vue-cli-service build", "build:sign": "cross-env PROJECT_NAME=sign vue-cli-service build", "build:track": "cross-env PROJECT_NAME=track vue-cli-service build", "build:approval": "cross-env PROJECT_NAME=approval vue-cli-service build", "lint": "vue-cli-service lint" },
好了,運行不同的命令試試吧。我反反復復有些莫名的報錯,重裝cross-env也反復好幾次,全局的,局部都試過。再比如 dev 不行,dev:main就可以,我就刪除了node-modules,重新下載了依賴,就可以了。 呼~~~~ 終于搞定了,希望大家能少走一些坑,拜拜~~~
總結
到此這篇關于Vue項目分包打包配置(包含dev)的文章就介紹到這了,更多相關Vue分包打包配置內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue在頁面和方法中如何通過遍歷對象獲取對象的鍵(key)和值(value)
這篇文章主要介紹了vue在頁面和方法中如何通過遍歷對象獲取對象的鍵(key)和值(value)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05使用Vue Composition API寫出清晰、可擴展的表單實現(xiàn)
這篇文章主要介紹了使用Vue Composition API寫出清晰、可擴展的表單實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06vue-print-nb實現(xiàn)頁面打印功能實例(含分頁打印)
在項目中,有時需要打印頁面的表格,在網(wǎng)上找了一個打印組件vue-print-nb,用了還不錯,所以下面這篇文章主要給大家介紹了關于vue-print-nb實現(xiàn)頁面打印功能的相關資料,需要的朋友可以參考下2022-08-08