gulp使用'transform-runtime'时出现'require is not defined'问题
为了在项目中使用es2017的异步函数。
所以在使用gulp处理js文件时,我使用了'babel-preset-env'和'babel-plugin-transform-runtime'。
解析后出现了nodejs的require语法,所以浏览器报错了。
我应该如何处理这种情况。
希望能得到解答,谢谢。
1.项目依赖:
2.gulpfile.js文件配置:
3.js文件和解析后的文件:
4.浏览器报错:
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
这个是 commonjs 包规范。你应该再配合一个 wepack,或者引入 commonjs 库。
babel-plugin-transform-runtime
库是 modular 的。如果确定需要引入的话,则需转换 CommonJS 。用 gulp 可以看看 webpack-stream,或者直接用 webpack 或 Browserify 。
我跟你遇到一样的问题,已测试过可用。我之前是先用browserify,再用babel,所以后面使用babel打包后代码出现的var _typeof2=require("babel-runtime/helpers/typeof"),require没有被解析所以才会有require is not define的问题。
正确解决方案:
求楼上详细点:我也遇到同样的问题,当js文件里面有 Promise等需要 babel-polyfill转的时候,转出来的合并的文件中有 require(""),但这并不是浏览器端的词法环境,导致requrie is not defined...求解...