微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在 NextJS 应用程序中使用 Babel 从 node_modules 转换导入语法?

如何解决如何在 NextJS 应用程序中使用 Babel 从 node_modules 转换导入语法?

当使用 Babel 从我的 node_modules 转译 es6 模块时,我的构建中断并出现以下错误

SyntaxError: Cannot use import statement outside a module
    at wrapSafe (internal/modules/cjs/loader.js:915:16)
    at Module._compile (internal/modules/cjs/loader.js:963:27)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1027:10)
    at Module.load (internal/modules/cjs/loader.js:863:32)
    at Function.Module._load (internal/modules/cjs/loader.js:708:14)
    at Module.require (internal/modules/cjs/loader.js:887:19)
    at require (internal/modules/cjs/helpers.js:74:18)

我使用以下 nextJS/webpack 配置:

const withLess = require('@zeit/next-less');
const withPreact = require('next-plugin-preact');
const path = require('path');

module.exports = withPreact(withLess( {
    webpack: (config) => {
        config.module.rules.push({
            test: /\.js|jsx$/,include: (modpath) => {
                return modpath.indexOf('@my-org') !== -1 || modpath.indexOf('node_modules') === -1
            },use: {
                loader: 'babel-loader',options: {
                    presets: ['next/babel','@babel/preset-flow','@babel/preset-env']
                },},});
        return config;
    },}));


我组织的模块似乎没有转换。虽然我可以通过检查包含功能来确认它们是“包含”的。

如何让 babel 从 node_modules 文件夹中转换 es6 模块?

解决方法

我用这个 webpack 插件解决了:

https://www.npmjs.com/package/next-transpile-modules

const withLess = require('@zeit/next-less');
const withPreact = require('next-plugin-preact');


const withTM = require('next-transpile-modules')(()=>{
  // should return array with module paths
});


module.exports = withTM(withPreact(withLess( {
    webpack: (config) => {
        config.module.rules.push({
            test: /\.js|jsx$/,use: {
                loader: 'babel-loader',options: {
                    presets: ['next/babel','@babel/preset-flow','@babel/preset-env']
                },},});
        return config;
    },})));

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。