vite vue3 config配置篇

关于vite初始化项目参考自 https://vitejs.cn/
配置基于自生产上线项目所使用配置

vite.config.js

导入模块内容

import { defineConfig } from 'vite' #vite配置
import vue from '@vitejs/plugin-vue' #vue
import vueJsx from '@vitejs/plugin-vue-jsx' #支持jsx
import viteSvgIcons from 'vite-plugin-svg-icons' # svg
import { resolve } from "path"; # 引用项目地址
import OptimizationPersist from 'vite-plugin-optimize-persist' 
import PkgConfig from 'vite-plugin-package-config' #解决加载缓慢自动填充package.json
import legacy from '@vitejs/plugin-legacy' #浏览器兼容
import importToCDN from 'vite-plugin-cdn-import' # node_modules内容走CDN配置 缓解打包过大加载慢(服务器带宽不够)

配置alias

// search path
const pathResolve = (dir) => {
  return resolve(__dirname, ".", dir);
};

//set alias
const alias = [
  {
    find: '@',
    replacement: pathResolve("src")
  },
  {
    find: '~',
    replacement: pathResolve("./")
  },
  {
    find: "@build",
    replacement: pathResolve("build")}
];

defineConfig server

server:{
    https: false, //本地环境不用https
    hrm: true,
    port: 8080, //本地端口
    host: '0.0.0.0', 
    proxy: { //反向代理配置
      '/api': {
        target: 'http://localhost:8090/',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, '')
      }
    },
  },

defineConfig plugins

添加项目中引用添加svg项 浏览器兼容问题 以及所需框架使用cdn加速(因服务器带宽有限不想打包时过大加载过慢问题)

plugins: [
    vue(),
    vueJsx(),
// 配置svg项 监听项目路径地址 并做icon替换
    viteSvgIcons({
      iconDirs: [resolve(process.cwd(), 'src/icons/svg')],
      symbol: 'icon-[dir]-[name]'
    }),
    PkgConfig(),
    OptimizationPersist(),
    legacy({
      targets: ['ie >= 11'],
      additionalLegacyPolyfills: ['regenerator-runtime/runtime']
    }),
    importToCDN({
      modules: [
        {
          name:'vue',
          var:'Vue',
          path:'https://npm.elemecdn.com/vue@3.2.25/dist/vue.global.prod.js'
        },
        {
          name:'vuex',
          var:'Vuex',
          path:'https://npm.elemecdn.com/vuex@4.0.2/dist/vuex.global.prod.js'
        },
        {
          name:'vue-router',
          var:'VueRouter',
          path:'https://npm.elemecdn.com/vue-router@4.0.12/dist/vue-router.global.prod.js'
        },
        {
          name: 'element-plus',
          var: 'ElementPlus',
          path: `https://npm.elemecdn.com/element-plus@2.1.8/dist/index.full.min.js`,
          css: 'https://npm.elemecdn.com/element-plus@2.1.8/dist/index.css',
        },
        {
          name: 'nprogress',
          var: 'NProgress',
          path: `https://npm.elemecdn.com/nprogress@0.2.0/nprogress.js`,
          css: 'https://npm.elemecdn.com/nprogress@0.2.0/nprogress.css',
        },
        {
          name: 'echarts',
          var: 'echarts',
          path: `https://npm.elemecdn.com/echarts@5.3.3/dist/echarts.min.js`
        }       
      ]
    })
  ],

defineConfig resolve

该内容配置@ 及~ 因为习惯于vue-cli 2.x时候import习惯@找文件并且不添加后缀 直接在配置项内添加后缀为.vue,.js以及.json文件

resolve: {
    alias,
    extensions: ['.vue', '.js', '.json']
  },

defineConfig build

build: {
    target: 'es2020',
    cssCodeSplit: false,
    minify: 'terser', // 混淆器,terser构建后文件体积更小
    sourcemap: false,
    terserOptions: {
      compress: {
        drop_console: true, // 生产环境移除console
        drop_debugger: true // 生产环境移除debugger
      }
    },
    rollupOptions: {
      treeshake: false,
      output: {
        manualChunks (id) {
          if (id.includes('node_modules')) {
            return id.toString().split('node_modules/')[1].split('/')[0].toString()
          }
        }
      }
    }
  },

完整配置内容

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import vueJsx from '@vitejs/plugin-vue-jsx'
import viteSvgIcons from 'vite-plugin-svg-icons'
import { resolve } from "path";
import OptimizationPersist from 'vite-plugin-optimize-persist'
import PkgConfig from 'vite-plugin-package-config'
import legacy from '@vitejs/plugin-legacy'
import importToCDN from 'vite-plugin-cdn-import'
// search path
const pathResolve = (dir) => {
  return resolve(__dirname, ".", dir);
};

//set alias
const alias = [
  {
    find: '@',
    replacement: pathResolve("src")
  },
  {
    find: '~',
    replacement: pathResolve("./")
  },
  {
    find: "@build",
    replacement: pathResolve("build")}
];


// https://vitejs.dev/config/
export default defineConfig({
  base: '/',
  server:{
    https: false,
    hrm: true,
    port: 8080,
    host: '0.0.0.0',
    proxy: {
      '/api': {
        target: 'http://localhost:8090/',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, '')
      }
    },
  },
  plugins: [
    vue(),
    vueJsx(),
    viteSvgIcons({
      iconDirs: [resolve(process.cwd(), 'src/icons/svg')],
      symbol: 'icon-[dir]-[name]'
    }),
    PkgConfig(),
    OptimizationPersist(),
    legacy({
      targets: ['ie >= 11'],
      additionalLegacyPolyfills: ['regenerator-runtime/runtime']
    }),
    importToCDN({
      modules: [
        {
          name:'vue',
          var:'Vue',
          path:'https://npm.elemecdn.com/vue@3.2.25/dist/vue.global.prod.js'
        },
        {
          name:'vuex',
          var:'Vuex',
          path:'https://npm.elemecdn.com/vuex@4.0.2/dist/vuex.global.prod.js'
        },
        {
          name:'vue-router',
          var:'VueRouter',
          path:'https://npm.elemecdn.com/vue-router@4.0.12/dist/vue-router.global.prod.js'
        },
        {
          name: 'element-plus',
          var: 'ElementPlus',
          path: `https://npm.elemecdn.com/element-plus@2.1.8/dist/index.full.min.js`,
          css: 'https://npm.elemecdn.com/element-plus@2.1.8/dist/index.css',
        },
        {
          name: 'nprogress',
          var: 'NProgress',
          path: `https://npm.elemecdn.com/nprogress@0.2.0/nprogress.js`,
          css: 'https://npm.elemecdn.com/nprogress@0.2.0/nprogress.css',
        },
        {
          name: 'echarts',
          var: 'echarts',
          path: `https://npm.elemecdn.com/echarts@5.3.3/dist/echarts.min.js`
        }       
      ]
    })
  ],
  resolve: {
    alias,
    extensions: ['.vue', '.js', '.json']
  },
  css: {
    postcss: {
      plugins: [
        {
          postcssPlugin: 'internal:charset-removal',
          AtRule: {
            charset: (atRule) => {
              if (atRule.name === 'charset') {
                atRule.remove();
              }
            }
          }
        }
      ],
    },
  },
  build: {
    target: 'es2020',
    cssCodeSplit: false,
    minify: 'terser', // 混淆器,terser构建后文件体积更小
    sourcemap: false,
    terserOptions: {
      compress: {
        drop_console: true, // 生产环境移除console
        drop_debugger: true // 生产环境移除debugger
      }
    },
    rollupOptions: {
      treeshake: false,
      output: {
        manualChunks (id) {
          if (id.includes('node_modules')) {
            return id.toString().split('node_modules/')[1].split('/')[0].toString()
          }
        }
      }
    }
  },
})

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容