ExternalsPlugin

このプラグインを使用すると、出力ファイルにバンドルすべきでない外部依存関係を指定できます。これは、グローバルに既に利用可能であるか、他のスクリプトによって管理されているライブラリに特に役立ちます。externalsType および externals の構成は、内部的にこのプラグインを利用します。したがって、プラグインを個別に使用する必要なく、これらの構成オプションを通じてそれぞれの機能を直接利用できます。

new rspack.ExternalsPlugin(type, externals);

オプション

type

タイプ

type ExternalsType =
  | 'var'
  | 'module'
  | 'assign'
  | 'this'
  | 'window'
  | 'self'
  | 'global'
  | 'commonjs'
  | 'commonjs2'
  | 'commonjs-module'
  | 'commonjs-static'
  | 'amd'
  | 'amd-require'
  | 'umd'
  | 'umd2'
  | 'jsonp'
  | 'system'
  | 'promise'
  | 'import'
  | 'script'
  | 'node-commonjs';

externals のデフォルトのタイプを指定します。

詳細については、externalsTypeを参照してください。

externals

タイプ

type Externals = ExternalItem[] | ExternalItem;

type ExternalItem =
  | RegExp
  | string
  | (
      | ((
          data: ExternalItemFunctionData,
          callback: (err?: Error | null, result?: ExternalItemValue) => void,
        ) => void)
      | ((data: ExternalItemFunctionData) => Promise<ExternalItemValue>)
    );

type ExternalItemValue =
  | string[]
  | boolean
  | string
  | {
      [k: string]: any;
    };

type ExternalItemFunctionData = {
  context?: string;
  contextInfo?: ModuleFactoryCreateDataContextInfo;
  getResolve?: (
    options?: ResolveOptions,
  ) =>
    | ((
        context: string,
        request: string,
        callback: (err?: Error, result?: string) => void,
      ) => void)
    | ((context: string, request: string) => Promise<string>);
  request?: string;
};

type ModuleFactoryCreateDataContextInfo = {
  issuer: string;
  compiler: string;
};

特定の import されたパッケージのバンドルを防止し、代わりにこれらの外部依存関係を実行時に取得します。

詳細については、externalsを参照してください。

このページの内容