使用react-toastify会报错 non EcmaScript module

最近在用React写一个页面,想加入一个Message通知弹窗,找了很久,最终选用了react-toastify。主要是他配置比较简单,所以按照他们的示例进行了配置。

 import React from 'react';

  import { ToastContainer, toast } from 'react-toastify';
  import 'react-toastify/dist/ReactToastify.css';
  
  function App(){
    const notify = () => toast("Wow so easy!");

    return (
      <div>
        <button onClick={notify}>Notify!</button>
        <ToastContainer />
      </div>
    );
  }

然后运行

Failed to compile.

./node_modules/react-toastify/dist/react-toastify.esm.mjs
Can't import the named export 'cloneElement' from non EcmaScript module (only default export is available)
Compiling...

就报错了,找了半天的原因,貌似是因为最新版本的React不支持非ES语法的模块

在这里插入图片描述

最终就采取其他的方式解决一下吧
首先 安装 react-app-rewired

npm install --save-dev react-app-rewired

然后在 package.json中修改 react-scriptsreact-app-rewired

 "scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "test": "react-app-rewired test",
    "eject": "react-scripts eject"
},

然后在根目录创建一个 config-overrides.js

 module.exports = function override(webpackConfig) {
  webpackConfig.module.rules.push({
    test: /\.mjs$/,
    include: /node_modules/,
    type: "javascript/auto"
  });

  return webpackConfig;
}

然后正常的 npm start 就可以了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值