我想把我的一个旧模块重写为ESNext。为了捆绑它,我使用Rollup,编译它回来,当然,我使用Babel。所有这些都是由古尔普管弦乐队演奏的。
到目前为止,所有这些都进行得很顺利,同时升级到Babel v7、Gulp v4和最新版本的rollup (v0.56.0)。但是现在,由于我打算在我的babel配置中包括useBuiltIns: true,所以我不必担心填充问题,所以我会得到一个由rollup引发的错误:
TypeError: Cannot read property 'code' of null
at error (/Users/robin.loeffel/Sites/misc/jz2/node_modules/rollup/dist/rollup.js:168:15)
at Object.error (/Users/robin.loeffel/Sites/misc/jz2/node_modules/rollup/dist/rollup.js:17916:21)
at /Users/robin.loeffel/Sites/misc/jz2/node_modules/rollup/dist/rollup.js:17925:29
at <anonymous>你可以看看我的吞咽文件这里。很简单。我使用rollup-stream与gulp集成,并使用rollup-plugin-babel、rollup-plugin-uglify、rollup-plugin-node-resolve和rollup-plugin-commonjs作为插件。下面是我如何集成它的一个例子,如果您没有时间查看整个过程:
gulp.task('make:iife:min', () => {
return rollupStream({
input: config.paths.index,
output: {
format: 'iife',
name: 'jazzer'
},
plugins: [
rollupNodeResolve(),
rollupCommonJs(),
rollupBabel(config.babel),
rollupUglify()
],
rollup: rollup
})
.pipe(source('jazzer.min.js'))
.pipe(gulp.dest(config.paths.dist));
});我的Babel配置如下:
{
presets: [
['@babel/preset-env', {
targets: {
ie: 11,
browsers: 'last 2 versions'
},
useBuiltIns: 'usage',
modules: false,
debug: true
}]
],
ignore: ['node_modules']
}当我用rollupNodeResolve评论行,禁用插件时,它会编译,但会给我一个警告,比如'regenerator-runtime/runtime' is imported by src/jazzer.js, but could not be resolved – treating it as an external dependency。注释掉ignore: ['node_modules']会导致Babel导入太多的东西并产生83 kb的包,所以这也不是一种方法。
希望有人能帮我!和下面是整个回购,如果你想看看它,看看自己。
发布于 2018-02-15 21:04:44
这是rollup插件中的一个bug。我已经帮你归档了:https://github.com/rollup/rollup-plugin-babel/issues/192
https://stackoverflow.com/questions/48811861
复制相似问题