Error: Plugin/Preset files are not allowed to export objects, only functions
- package.json 的依赖列表即有 babel 7.0 版本的( @babel/core , @babel/preset-react )
也有 babel 6.0 版本的 ( babel-core@6.26.0 , babel-cli@6.26.0 , babel-preset-react@6.24.1 )
也可命令查看 bebel-cli 的版本 ( babel -V )
如果在你的 package.json 依赖包中既有 babel 7.0 版本,又有 babel 6.0 版本,就会报这个错误
很显然就是两个版本是不兼容的
- 处理方法
- 我自己把babel-loader版本改低了,原来是8
- 在package.json中改为:“babel-loader”: “^7.1.2”,先把package-lock.json删除
1、升级到 babel 7.0
将所有有关 babel 的包都升级为 7.0 版本
"@babel/core": "^7.0.0-beta.40",
"@babel/cli": "^7.0.0-beta.40",
"babel-loader": "^8.0.0-beta.0",
"babel-plugin-lodash": "^3.3.2",
"babel-plugin-react-transform": "^3.0.0",
"@babel/preset-react": "^7.0.0-beta.40",<br>"@babel/preset-stage-0":'^7.0.0'
并且修改 .babelrc 文件
对应的修改 presets 预设和 plugins 都改为 7.0 形式。
query: {
presets: ['@babel/react', '@babel/stage-0'],
plugins: ['']
}
2、降级到 babel 6.0 版本
有时候我们看们的 package.json 里面都是 babel 6.0 版本的。
如下:
"babel-core": "^6.26.0",
"babel-loader": "^7.1.2",
"babel-plugin-transform-runtime": "^6.23.0",
"babel-preset-env": "^1.6.1",
"babel-preset-stage-0": "^6.24.1",
但是还是报错,为什么呢?
你不妨把 node_modules 删掉,重新 install ,这样就可以处理一部分兼容问题
如果上面的方法还是不行,你可以查看一下 babel-cli 的版本
babel -V
如果是 babel-cli 7.0 版本。
那你就重新安装全局和本地的 babel-cli 版本为 6.0
npm install -g babel-cli@6.26.0
yarn add babel-cli@6.26.0
安装babel-cli全局变量
npm install babel-cli -g
babel -V
配置babel-cli
我们在babel目录新建.babelrc文件(这是babel的配置文件),Windows下可以用如下命令创建。
echo. > .babelrc
用记事本打开,输入以下内容
{
"presets": ["es2015", "stage-2"], //设置转码规则
"plugins": ["transform-runtime"] //设置插件
}
这里我们配置好了babel的转码规则,转码成es2015.官方提供以下的规则集,可以根据需要安装:
# ES2015转码规则
npm install --save-dev babel-preset-es2015
# react转码规则
npm install --save-dev babel-preset-react
# ES7不同阶段语法提案的转码规则(共有4个阶段),选装一个
npm install --save-dev babel-preset-stage-0
npm install --save-dev babel-preset-stage-1
npm install --save-dev babel-preset-stage-2
npm install --save-dev babel-preset-stage-3
这里我们只需要转换成es2015,这里我们安装我们需要的部分:
npm install babel-core babel-preset-es2015 babel-plugin-transform-runtime babel-preset-stage-2 –save-dev
如需其他配置,可以修改.babelrc文件,然后安装上面对于的插件。我们再打开我们babel项目下的package.json文件,做如下修改。