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

@babel/plugin-proposal-import-defer

import defer 宣言を遅延した require() 呼び出しに変換します。

注意

このプラグインは、モジュールを CommonJS にコンパイルする場合にのみ使用できます。

input.js
import defer * as lib from "lib";

later(() => {
console.log(lib.value);
});

は次のように変換されます。

output.js
"use strict";

function lib(data) {
lib = () => data;
return data = _interopRequireWildcard(require("lib"));
}

later(() => {
console.log(lib().value);
});

インストール

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

使用方法

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

CLI 経由

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

Node API 経由

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

リファレンス