跳至主要内容

@babel/plugin-transform-modules-amd

历史
版本变更
v7.14.0实现了 importInterop 选项
信息

此插件包含在 @babel/preset-envmodules 选项下

此插件将 ECMAScript 模块转换为 AMD。请注意,只有导入/导出语句(import "./mod.js")和导入表达式(import('./mod.js'))的*语法*会被转换,因为 Babel 不知道 ECMAScript 模块和 AMD 实现之间不同的解析算法。

示例

输入

JavaScript
export default 42;

输出

JavaScript
define(["exports"], function(exports) {
"use strict";

Object.defineProperty(exports, "__esModule", {
value: true,
});

exports.default = 42;
});

安装

npm install --save-dev @babel/plugin-transform-modules-amd

用法

babel.config.json
{
"plugins": ["@babel/plugin-transform-modules-amd"]
}

通过 CLI

Shell
babel --plugins @babel/plugin-transform-modules-amd script.js

通过 Node API

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

选项

moduleIds

boolean 默认为 !!moduleId

添加于:v7.9.0

启用模块 ID 生成。

moduleId

字符串

添加于:v7.9.0

用于模块的硬编码 ID。不能与 getModuleId 一起使用。

getModuleId

(name: string) => string

添加于:v7.9.0

给定 Babel 生成的模块名称,返回要使用的名称。返回假值将使用原始的 name

moduleRoot

字符串

添加于:v7.9.0

要包含在生成的模块名称上的根路径。

有关此处未列出的选项,请参阅 @babel/plugin-transform-modules-commonjs 的选项。