vite.config.build.taro.vue.disperse.ts 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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) 2021 @jdf2e.
  9. * Released under the MIT License.
  10. */`;
  11. let input = {};
  12. configPkg.nav.map((item) => {
  13. item.packages.forEach((element) => {
  14. let { name, show, taro, type, exportEmpty } = element;
  15. if (taro && (show || exportEmpty)) {
  16. input[name] = `./src/packages/__VUE/${name.toLowerCase()}/index${exportEmpty ? '.vue' : '.taro.vue'}`;
  17. }
  18. });
  19. });
  20. export default defineConfig({
  21. resolve: {
  22. alias: [{ find: '@', replacement: path.resolve(__dirname, './src') }]
  23. },
  24. plugins: [vue()],
  25. build: {
  26. minify: false,
  27. terserOptions: {
  28. compress: {
  29. drop_console: true,
  30. drop_debugger: true
  31. }
  32. },
  33. lib: {
  34. entry: '',
  35. name: 'index',
  36. // fileName: (format) => format,
  37. formats: ['es']
  38. },
  39. rollupOptions: {
  40. // 请确保外部化那些你的库中不需要的依赖
  41. external: ['vue', 'vue-router', '@tarojs/taro', 'pinyin'],
  42. input,
  43. output: {
  44. banner,
  45. dir: path.resolve(__dirname, './dist/packages/_es'),
  46. entryFileNames: '[name].js'
  47. }
  48. },
  49. emptyOutDir: false
  50. }
  51. });