vite vue3 config配置篇

作者: H_小猪 | 来源:发表于2022-08-04 14:57 被阅读0次

关于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()
          }
        }
      }
    }
  },
})

相关文章

网友评论

    本文标题:vite vue3 config配置篇

    本文链接:https://www.haomeiwen.com/subject/vhepwrtx.html