欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue項目分包打包配置(包含dev)完整過程

 更新時間:2023年06月08日 10:52:11   作者:管小姐的斐波那契  
最近接到一個需求,公司需要對vue項目實現(xiàn)線上打包,下面這篇文章主要給大家介紹了關于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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解Vue3-pinia狀態(tài)管理

    詳解Vue3-pinia狀態(tài)管理

    這篇文章主要介紹了Vue3-pinia狀態(tài)管理,pinia是?vue3?新的狀態(tài)管理工具,簡單來說相當于之前?vuex,它去掉了?Mutations?但是也是支持?vue2?的,需要的朋友可以參考下
    2022-08-08
  • vue在頁面和方法中如何通過遍歷對象獲取對象的鍵(key)和值(value)

    vue在頁面和方法中如何通過遍歷對象獲取對象的鍵(key)和值(value)

    這篇文章主要介紹了vue在頁面和方法中如何通過遍歷對象獲取對象的鍵(key)和值(value)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue 中 a標簽上href無法跳轉的解決方式

    Vue 中 a標簽上href無法跳轉的解決方式

    今天小編大家分享一篇Vue 中 a標簽上href無法跳轉的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 使用Vue Composition API寫出清晰、可擴展的表單實現(xiàn)

    使用Vue Composition API寫出清晰、可擴展的表單實現(xiàn)

    這篇文章主要介紹了使用Vue Composition API寫出清晰、可擴展的表單實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • 利用vue和element-ui設置表格內容分頁的實例

    利用vue和element-ui設置表格內容分頁的實例

    下面小編就為大家分享一篇利用vue和element-ui設置表格內容分頁的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue實現(xiàn)電梯樣式錨點導航效果流程詳解

    Vue實現(xiàn)電梯樣式錨點導航效果流程詳解

    這篇文章主要介紹了Vue實現(xiàn)電梯樣式錨點導航效果流程,這種導航效果廣泛應用于商城點餐購物情景,文中通過示例代碼介紹的很詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-05-05
  • vue計算屬性及函數(shù)的選擇

    vue計算屬性及函數(shù)的選擇

    這篇文章主要介紹了vue計算屬性及函數(shù)的選擇,文章圍繞主題的相關資料展開詳細介紹,需要的小伙伴可以參考一下
    2022-05-05
  • vue-print-nb實現(xiàn)頁面打印功能實例(含分頁打印)

    vue-print-nb實現(xiàn)頁面打印功能實例(含分頁打印)

    在項目中,有時需要打印頁面的表格,在網(wǎng)上找了一個打印組件vue-print-nb,用了還不錯,所以下面這篇文章主要給大家介紹了關于vue-print-nb實現(xiàn)頁面打印功能的相關資料,需要的朋友可以參考下
    2022-08-08
  • Vue 仿百度搜索功能實現(xiàn)代碼

    Vue 仿百度搜索功能實現(xiàn)代碼

    本文通過實例代碼給大家介紹了vue仿百度搜索功能,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧
    2017-02-02
  • Vue兩個通信方式與動畫過度及混入使用介紹

    Vue兩個通信方式與動畫過度及混入使用介紹

    最近在寫vue的一個項目要實現(xiàn)過渡的效果,雖然vue動畫不是強項,庫也多,但是基本的坑還是得踩扎實,下面這篇文章主要給大家介紹了關于Vue中實現(xiàn)過渡動畫效果的相關資料,需要的朋友可以參考下
    2023-03-03

最新評論