@mdd-all/vite-plugin-build
TypeScript icon, indicating that this package has built-in type declarations

0.1.0 • Public • Published

@mdd-all/vite-plugin-build

vite-plugin-build@0.10.0 修改以兼容nx

vite 库模式插件,支持单个文件转换(vite 的默认模式),支持多个输入文件多个输出文件模式,也支持整个文件夹的转换模式。

  • 支持多入口文件和多输出文件
  • 支持整个文件夹转换
  • 支持 vanilla、react、vue3、svelte 的代码转换
  • 支持 typescript 声明文件生成(vanilla、react、vue3、svelte)

默认文件夹模式

import { defineConfig } from 'vite';
import { buildPlugin } from '@mdd-all/vite-plugin-build';

export default defineConfig({
  plugins: [buildPlugin()],
});

生成声明文件

import { defineConfig } from 'vite';
import { buildPlugin } from '@mdd-all/vite-plugin-build';

export default defineConfig({
  plugins: [buildPlugin({ fileBuild: { emitDeclaration: true } })],
});

多输入多输出模式

import { defineConfig } from 'vite';
import { buildPlugin } from '@mdd-all/vite-plugin-build';

export default defineConfig({
  plugins: [
    buildPlugin({
      fileBuild: false,
      libBuild: {
        buildOptions: [
          {
            lib: {
              entry: path.resolve(__dirname, 'src/a.ts'),
              name: 'A',
              formats: ['umd'],
              fileName: () => `a.js`,
            },
          },
          {
            lib: {
              entry: path.resolve(__dirname, 'src/b.ts'),
              name: 'b',
              formats: ['umd'],
              fileName: () => `b.js`,
            },
          },
        ],
      },
    }),
  ],
});

在线试用

注意

使用此插件后,默认的 vite 配置 build 字段将无效。

选项

export interface Options {
  /**
   * vite 库模式配置,入口文件打包成一个文件,不配置则不开启此功能
   */
  libBuild?: BuildLibOptions;
  /**
   * vite 库模式配置,指定文件夹下的所有 js 或者 ts 文件转成 commonjs 和 es module 的文件
   * 默认开启此功能
   */
  fileBuild?: FileBuild | false;
}

options.libBuild

export interface BuildLibOptions {
  /**
   * 同 vite 配置字段 build,同时支持数组配置,支持多输入多输出
   */
  buildOptions: BuildOptions | BuildOptions[];
}

options.fileBuild

export interface FileBuild extends BuildFilesOptions {
  /**
   * 是否导出 typescript 声明文件
   */
  emitDeclaration?: boolean;
  /**
   * 是否是 vue 文件构建,配合 emitDeclaration 来处理
   * 使用官方的插件 @vitejs/plugin-vue,默认为 true
   */
  isVue?: boolean;
  /**
   * 是否是 svelte 文件构建,配合 emitDeclaration 来处理
   * 使用官方的插件 @sveltejs/vite-plugin-svelte,默认为 true
   */
  isSvelte?: boolean;
}

export interface BuildFilesOptions {
  /**
   * 输入文件夹,相对于项目根目录下,格式为 `src` 或者 `src/test`
   * @defaults src
   */
  inputFolder?: string;
  /**
   * 支持转换的文件后缀名
   * @defaults ['ts', 'tsx', 'js', 'jsx', 'vue', 'svelte']
   */
  extensions?: string[];
  /**
   * es 文件输出路径,设置为 false 相当于关闭 es 模块的构建
   * @defaults es
   */
  esOutputDir?: string | false;
  /**
   * commonjs 文件输出路径,设置为 false 相当于关闭 commonjs 模块的构建
   * @defaults lib
   */
  commonJsOutputDir?: string | false;
  /**
   * 忽略的转换文件,只支持 glob 语法
   * @defaults ['\*\*\/\*.spec.\*', '\*\*\/\*.test.\*', '\*\*\/\*.d.ts']
   */
  ignoreInputs?: string[];
  /**
   * 此配置会覆盖所有当前构建中 vite config 中 build 配置,
   * 建议优先使用 rollupOptionsOutput、rollupOptionsExternal等其他字段配置
   * 支持函数,第一个参数是入口文件路径
   */
  buildOptions?: BuildOptions | ((inputFilePath: string) => BuildOptions);
  /**
   * 和 rollup output 配置一致,会同时作用在 commonjs 和 es output 配置
   * 支持函数,第一个参数是转换的文件路径
   */
  rollupOptionsOutput?: OutputOptions | ((outputFilePath: string) => OutputOptions);
  /**
   * 和 rollup external 配置一致,
   * 由于 external 不能把自身归属于外部依赖,所以函数模式的参数增加了第四个参数:入口文件相对路径
   * 重新定义 external 需要这样判断:if(id.includes(path.resolve(fileRelativePath))) { return false }
   */
  rollupOptionsExternal?:
    | (string | RegExp)[]
    | string
    | RegExp
    | ((
        source: string,
        importer: string | undefined,
        isResolved: boolean,
        inputFilePath: string,
      ) => boolean | null | void);
}

使用例子

可参考 examples 文件夹下的例子。

只支持文件夹转 commonjs

这是拓展的功能,vite 本身不支持,默认转换文件夹是根目录的 src 文件夹。

import { defineConfig } from 'vite';
import { buildPlugin } from '@mdd-all/vite-plugin-build';

export default defineConfig({
  plugins: [buildPlugin({ fileBuild: { onlyCjs: true } })],
});

支持单个入口文件转换为 umd 格式

这是 vite 本身支持的 vite 库模式。

import { defineConfig } from 'vite';
import { buildPlugin } from '@mdd-all/vite-plugin-build';

export default defineConfig({
  plugins: [
    buildPlugin({
      libBuild: {
        buildOptions: {
          rollupOptions: {
            external: ['react', 'react-dom'],
            output: {
              globals: {
                react: 'React',
                'react-dom': 'ReactDOM',
              },
            },
          },
          lib: {
            entry: path.resolve(__dirname, 'src/index.ts'),
            name: 'RbacComponents',
            fileName: (format) => `rbac-components.${format}.js`,
          },
        },
      },
    }),
  ],
});

文件夹转换模式配置 external

文件夹转换模式默认的 external 默认如下:

function external(id) {
  if (isAsset() || isVueTempFile(id) || id === path.resolve(process.cwd(), fileRelativePath)) {
    return false;
  }
  return true;
}

less、css、svg 文件会打包,其他都当中外包依赖包,如果有其他需求,需要自己配置。

import { defineConfig } from 'vite';
import { buildPlugin } from '@mdd-all/vite-plugin-build';

export default defineConfig({
  plugins: [
    buildPlugin({
      fileBuild: {
        rollupOptionsExternal(id, importer, isResolved, fileRelativePath) {
          if (
            id.includes('.scss') ||
            // fileRelativePath 是当前入口文件
            id === path.resolve(process.cwd(), fileRelativePath)
          ) {
            return false;
          }
          return true;
        },
      },
    }),
  ],
});

修改输入文件

import { defineConfig } from 'vite';
import { buildPlugin } from '@mdd-all/vite-plugin-build';

export default defineConfig({
  plugins: [buildPlugin({ fileBuild: { inputFolder: 'main' } })],
});

Readme

Keywords

none

Package Sidebar

Install

npm i @mdd-all/vite-plugin-build

Weekly Downloads

2

Version

0.1.0

License

none

Unpacked Size

39.4 kB

Total Files

14

Last publish

Collaborators

  • mdd-all