vite.config.build.disperse.ts 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import { defineConfig } from 'vite';
  2. import vue from '@vitejs/plugin-vue';
  3. import path from 'path';
  4. import config from './package.json';
  5. import configPkg from './src/config.json';
  6. const banner = `/*!
  7. * ${config.name} v${config.version} ${new Date()}
  8. * (c) 2022 @jdf2e.
  9. * Released under the MIT License.
  10. */`;
  11. let input = {};
  12. configPkg.nav.map((item) => {
  13. item.packages.forEach((element) => {
  14. let { name, type } = element;
  15. input[name] = `./src/packages/__VUE/${name.toLowerCase()}/index${type === 'methods' ? '.ts' : '.vue'}`;
  16. });
  17. });
  18. export default defineConfig({
  19. resolve: {
  20. alias: [{ find: '@', replacement: path.resolve(__dirname, './src') }]
  21. },
  22. plugins: [vue()],
  23. build: {
  24. minify: false,
  25. terserOptions: {
  26. compress: {
  27. drop_console: true,
  28. drop_debugger: true
  29. }
  30. },
  31. lib: {
  32. entry: '',
  33. name: 'index',
  34. // fileName: (format) => format,
  35. formats: ['es']
  36. },
  37. rollupOptions: {
  38. // 请确保外部化那些你的库中不需要的依赖
  39. external: ['vue', 'vue-router'],
  40. input,
  41. output: {
  42. banner,
  43. dir: path.resolve(__dirname, './dist/packages/_es'),
  44. entryFileNames: '[name].js'
  45. }
  46. },
  47. emptyOutDir: false
  48. }
  49. });