gulp使用'transform-runtime'时出现'require is not defined'问题

发布于 2022-09-07 03:28:56 字数 649 浏览 30 评论 0

为了在项目中使用es2017的异步函数。
所以在使用gulp处理js文件时,我使用了'babel-preset-env''babel-plugin-transform-runtime'
解析后出现了nodejsrequire语法,所以浏览器报错了。
我应该如何处理这种情况。
希望能得到解答,谢谢。
1.项目依赖:
图片描述

2.gulpfile.js文件配置:
图片描述

3.js文件和解析后的文件:
图片描述
图片描述

4.浏览器报错:
图片描述

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

旧人哭 2022-09-14 03:28:56

这个是 commonjs 包规范。你应该再配合一个 wepack,或者引入 commonjs 库。

惟欲睡 2022-09-14 03:28:56

babel-plugin-transform-runtime 库是 modular 的。如果确定需要引入的话,则需转换 CommonJS 。

用 gulp 可以看看 webpack-stream,或者直接用 webpack 或 Browserify 。

深空失忆 2022-09-14 03:28:56

我跟你遇到一样的问题,已测试过可用。我之前是先用browserify,再用babel,所以后面使用babel打包后代码出现的var _typeof2=require("babel-runtime/helpers/typeof"),require没有被解析所以才会有require is not define的问题。
正确解决方案:

// @browserify 
var getBrowserifyStream = function() {
  return through.obj(function(file, env, callback) {
    var self = this,
      filePath = file.path;

    // browserify解析js
    var b = browserify({
      entries: filePath
    });

    b.bundle(function(err, buffer) {
      if (err) {
        errStream(self, err);
        return;
      }
      file._contents = buffer;
      callback(null, file);
    });
  });
};


 .pipe(babel({
      presets: ['es2015']
    }))
    // 使用browserify解析 require()
    .pipe(getBrowserifyStream())
枯叶蝶 2022-09-14 03:28:56

求楼上详细点:我也遇到同样的问题,当js文件里面有 Promise等需要 babel-polyfill转的时候,转出来的合并的文件中有 require(""),但这并不是浏览器端的词法环境,导致requrie is not defined...求解...

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文