vite.config.build.ts 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import { defineConfig } from 'vite';
  2. import vue from '@vitejs/plugin-vue';
  3. import Markdown from 'vite-plugin-md';
  4. import path from 'path';
  5. import config from './package.json';
  6. // https://vitejs.dev/config/
  7. const banner = `/*!
  8. * ${config.name} v${config.version} ${new Date()}
  9. * (c) 2021 @jdf2e.
  10. * Released under the MIT License.
  11. */`;
  12. export default defineConfig({
  13. resolve: {
  14. alias: [{ find: '@', replacement: path.resolve(__dirname, './src') }]
  15. },
  16. css: {
  17. preprocessorOptions: {
  18. scss: {
  19. // example : additionalData: `@import "./src/design/styles/variables";`
  20. // dont need include file extend .scss
  21. additionalData: `@import "@/styles/variables.scss";@import "@/sites/assets/styles/variables.scss";`
  22. }
  23. }
  24. },
  25. plugins: [
  26. vue({
  27. include: [/\.vue$/, /\.md$/]
  28. }),
  29. Markdown()
  30. ],
  31. build: {
  32. rollupOptions: {
  33. // 请确保外部化那些你的库中不需要的依赖
  34. external: ['vue'],
  35. output: {
  36. banner,
  37. // 在 UMD 构建模式下为这些外部化的依赖提供一个全局变量
  38. globals: {
  39. vue: 'Vue'
  40. }
  41. }
  42. },
  43. lib: {
  44. entry: 'src/nutui.ts',
  45. name: 'nutui',
  46. formats: ['es', 'umd']
  47. },
  48. emptyOutDir: false
  49. }
  50. });