当前位置:   article > 正文

vue3的vite配置_vue3 vite打包配置

vue3 vite打包配置

使用Vite快速构建Vue3+ts+pinia脚手架 

使用Vite快速构建Vue3+ts+pinia脚手架-51CTO.COM

1、现把下面导入的4个npm插件运行完成

  1. npm add -D terser
  2. npm i vite-plugin-imagemin -D
  3. npm i vite-plugin-compression -D
  4. npm i postcss-preset-env -D

2、然后复制配置文件进入 vite.config.ts 文件就可以使用了

  1. import { fileURLToPath, URL } from 'node:url'
  2. import { defineConfig } from 'vite'
  3. import vue from '@vitejs/plugin-vue'
  4. import vueJsx from '@vitejs/plugin-vue-jsx'
  5. // npm add -D terser 剔除console.log
  6. // npm i vite-plugin-imagemin -D
  7. import viteImagemin from 'vite-plugin-imagemin'
  8. // npm i vite-plugin-compression -D
  9. import viteCompression from 'vite-plugin-compression'
  10. // npm i postcss-preset-env -D
  11. import postcssPresetEnv from 'postcss-preset-env';
  12. // https://vitejs.dev/config/
  13. export default defineConfig({
  14. //静态资源服务的文件夹
  15. publicDir: 'public',
  16. base: './',
  17. //静态资源处理
  18. assetsInclude: '',
  19. //控制台输出的级别 info 、warn、error、silent
  20. logLevel: 'info',
  21. // 设为false 可以避免 vite 清屏而错过在终端中打印某些关键信息
  22. clearScreen: true,
  23. css: {
  24. postcss: {
  25. plugins: [postcssPresetEnv()] // 使用预设
  26. // 需要先安装预设: `npm i postcss-preset-env -D`
  27. }
  28. },
  29. plugins: [
  30. vue(),
  31. vueJsx(),
  32. viteCompression(), //代码体积压缩
  33. // 图片压缩
  34. viteImagemin({
  35. gifsicle: {
  36. optimizationLevel: 7,
  37. interlaced: false
  38. },
  39. optipng: {
  40. optimizationLevel: 7
  41. },
  42. mozjpeg: {
  43. quality: 20
  44. },
  45. pngquant: {
  46. quality: [0.8, 0.9],
  47. speed: 4
  48. },
  49. svgo: {
  50. plugins: [
  51. {
  52. name: 'removeViewBox'
  53. },
  54. {
  55. name: 'removeEmptyAttrs',
  56. active: false
  57. }
  58. ]
  59. }
  60. })
  61. ],
  62. resolve: {
  63. alias: {
  64. '@': fileURLToPath(new URL('./src', import.meta.url))
  65. },
  66. // 导入时想要省略的扩展名列表
  67. // 不建议使用 .vue 影响IDE和类型支持
  68. extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json']
  69. },
  70. //本地运行配置,以及反向代理配置
  71. server: {
  72. // host: 'localhost',
  73. host: true, // 监听所有地址
  74. // https: false, //是否启用 http 2
  75. cors: true, //为开发服务器配置 CORS , 默认启用并允许任何源
  76. open: true, //服务启动时自动在浏览器中打开应用
  77. port: 9000,
  78. // strictPort: false, //设为true时端口被占用则直接退出,不会尝试下一个可用端口
  79. // force: true, //是否强制依赖预构建
  80. // hmr: false, //禁用或配置 HMR 连接,是否保存自动刷新浏览器
  81. hmr: true,
  82. // 传递给 chockidar 的文件系统监视器选项
  83. watch: {
  84. ignored: ['!**/node_modules/your-package-name/**']
  85. },
  86. // 反向代理配置
  87. proxy: {
  88. '/api': {
  89. target: 'https://xxxx.com/',
  90. // target: 'http://127.0.0.1:8956/',
  91. changeOrigin: true,
  92. rewrite: (path) => path.replace(/^\/api/, '')
  93. }
  94. }
  95. },
  96. //生产环境不要日志,去掉console,debugger
  97. // esbuild: {
  98. // drop: ['console', 'debugger']
  99. // },
  100. //打包配置 默认这里是生产环境运行
  101. build: {
  102. //浏览器兼容性 "esnext"|"modules"
  103. target: 'modules',
  104. //指定输出路径
  105. outDir: 'dist',
  106. //生成静态资源的存放路径
  107. assetsDir: 'assets',
  108. //小于此阈值的导入或引用资源将内联为 base64 编码,以避免额外的 http 请求。设置为 0 可以完全禁用此项
  109. assetsInlineLimit: 4096,
  110. //启用/禁用 CSS 代码拆分
  111. cssCodeSplit: true,
  112. //构建后是否生成 source map 文件
  113. sourcemap: false,
  114. //自定义底层的 Rollup 打包配置
  115. rollupOptions: {},
  116. //@rollup/plugin-commonjs 插件的选项
  117. commonjsOptions: {},
  118. //构建的库
  119. // lib: {},
  120. //当设置为 true,构建后将会生成 manifest.json 文件
  121. manifest: false,
  122. // 设置为 false 可以禁用最小化混淆,
  123. // 或是用来指定使用哪种混淆器
  124. // boolean | 'terser' | 'esbuild'
  125. minify: 'terser', //terser 构建后文件体积更小
  126. //传递给 Terser 的更多 minify 选项。
  127. terserOptions: {
  128. //生产环境不要日志,去掉console,debugger
  129. compress: {
  130. drop_console: true,
  131. drop_debugger: true
  132. }
  133. },
  134. //设置为 false 来禁用将构建后的文件写入磁盘
  135. write: true,
  136. //默认情况下,若 outDir 在 root 目录下,则 Vite 会在构建时清空该目录。
  137. emptyOutDir: true,
  138. //启用/禁用 brotli 压缩大小报告
  139. // brotliSize: true,
  140. //chunk 大小警告的限制
  141. chunkSizeWarningLimit: 500
  142. }
  143. })

在使用npm run build 打包的文件后,不能直接在本地直接预览打包好的文件,直接预览报错:

 vite创建的项目,打包后的文件本地预览报错,原因是file文件不支持import,需要开启个服务。

可以在打包好文件后,在项目里面运行(查看打包好的文件):

npm run preview

或者预览打包项目参考 Vite打包后的dist不能直接在浏览器打开吗_vue打包dist文件可直接浏览器打开吗-CSDN博客

3、需要在移动端适配的:vite + vue3使用postcss-pxtorem适配移动端

参考:vite + vue3使用postcss-pxtorem适配移动端 - 知乎

4、vue3+vite配置全局scss

参考:vue3+vite配置全局scss - 掘金

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/86454
推荐阅读
相关标签
  

闽ICP备14008679号