plugins.ts 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. import { cdn } from "./cdn";
  2. import vue from "@vitejs/plugin-vue";
  3. // import { viteBuildInfo } from "./info";
  4. import svgLoader from "vite-svg-loader";
  5. import Icons from "unplugin-icons/vite";
  6. import type { PluginOption } from "vite";
  7. import vueJsx from "@vitejs/plugin-vue-jsx";
  8. import tailwindcss from "@tailwindcss/vite";
  9. import { configCompressPlugin } from "./compress";
  10. import removeNoMatch from "vite-plugin-router-warn";
  11. import { visualizer } from "rollup-plugin-visualizer";
  12. import removeConsole from "vite-plugin-remove-console";
  13. import { codeInspectorPlugin } from "code-inspector-plugin";
  14. // import { vitePluginFakeServer } from "vite-plugin-fake-server";
  15. export function getPluginsList(
  16. VITE_CDN: boolean,
  17. VITE_COMPRESSION: ViteCompression
  18. ): PluginOption[] {
  19. const lifecycle = process.env.npm_lifecycle_event;
  20. return [
  21. tailwindcss(),
  22. vue(),
  23. // jsx、tsx语法支持
  24. vueJsx(),
  25. /**
  26. * 在页面上按住组合键时,鼠标在页面移动即会在 DOM 上出现遮罩层并显示相关信息,点击一下将自动打开 IDE 并将光标定位到元素对应的代码位置
  27. * Mac 默认组合键 Option + Shift
  28. * Windows 默认组合键 Alt + Shift
  29. * 更多用法看 https://inspector.fe-dev.cn/guide/start.html
  30. */
  31. codeInspectorPlugin({
  32. bundler: "vite",
  33. hideConsole: true
  34. }),
  35. // viteBuildInfo(),
  36. /**
  37. * 开发环境下移除非必要的vue-router动态路由警告No match found for location with path
  38. * 非必要具体看 https://github.com/vuejs/router/issues/521 和 https://github.com/vuejs/router/issues/359
  39. * vite-plugin-router-warn只在开发环境下启用,只处理vue-router文件并且只在服务启动或重启时运行一次,性能消耗可忽略不计
  40. */
  41. removeNoMatch(),
  42. // mock支持
  43. // vitePluginFakeServer({
  44. // logger: false,
  45. // include: "mock",
  46. // infixName: false,
  47. // enableProd: true
  48. // }),
  49. // svg组件化支持
  50. svgLoader(),
  51. // 自动按需加载图标
  52. Icons({
  53. compiler: "vue3",
  54. scale: 1
  55. }),
  56. VITE_CDN ? cdn : null,
  57. configCompressPlugin(VITE_COMPRESSION),
  58. // 线上环境删除console
  59. removeConsole({ external: ["src/assets/iconfont/iconfont.js"] }),
  60. // 打包分析
  61. lifecycle === "report"
  62. ? visualizer({ open: true, brotliSize: true, filename: "report.html" })
  63. : (null as any)
  64. ];
  65. }