メインコンテンツへスキップ

@babel/plugin-proposal-dynamic-import

情報

このプラグインは、ES2020で`@babel/preset-env`に含まれています。

`import()`式を非ESMモジュール形式に変換します。

このプラグインを使う(使わない)場合

Webpack、Rollup、Parcelなどのバンドラーを使用している場合は、このプラグインを使用せず、バンドラーで`import()`式を処理する必要があります。

次の場合にこのプラグインを使用する必要があります。

このプラグインは、上記のモジュール変換プラグインのいずれかと一緒に使用する必要があります。

input.js
import("jquery").then($ => {});

は、以下に変換されます。

output.js
Promise.resolve()
.then(() => _interopRequireWildcard(require("jquery")))
.then(($) => {});

インストール

npm install --save-dev @babel/plugin-proposal-dynamic-import

使用方法

babel.config.json
{
"plugins": [
"@babel/plugin-proposal-dynamic-import",
"@babel/plugin-transform-modules-commonjs"
]
}

CLI経由

シェル
babel --plugins=@babel/plugin-proposal-dynamic-import,@babel/plugin-transform-modules-amd script.js

Node API経由

JavaScript
require("@babel/core").transformSync("code", {
plugins: [
"@babel/plugin-proposal-dynamic-import",
"@babel/plugin-transform-modules-systemjs"
],
});

参考文献