ExternalsPlugin

此外掛允許您指定不應綑綁到輸出檔案中的外部依賴項。這對於已經全域可用或由其他腳本管理的函式庫特別有用。 externalsTypeexternals 設定在內部利用此外掛。因此,您可以直接透過這些設定選項利用各自的功能,而無需單獨使用此外掛。

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