解决react报错 TypeError:_WEBPACK_IMPORTED_MODULE_0_react___default.a.createContext is not a function

react引用react-redux运行时出现下列报错:

TypeError:_WEBPACK_IMPORTED_MODULE_0_react___default.a.createContext is not a function

具体如图:

报错信息

原因有两种:

  • 与安装的React版本有关。它仅在React版本 > 16.3中可用
  • react-redux版本更新到6.0以上,版本过高

  这个主要是因为react最新版本抛弃使用了createClass这个函数,也是为了配合ES6 ,旧的不去新的不来,取而代之的就是目前常用的 class Welcome extends React.Component{}

解决方法:

方法一:提高react,react-dom版本

推荐使用:npm update react react-dom 提高到最新版本

或者手动自己修改成一个大于16.3的版本都可以

方法二:降低react-redux版本

首先将package.json文件下的react-redux版本号修改为5.0.6

后面在运行npm install,重新运行后,问题就会没了。

这个问题,react-redux官网上似乎也提到了,奈何英语不用太好,也没怎么读懂,想研究的可以去看下Accessing the Store


自建博客地址:ahuiyo的博客:
解决react报错 TypeError:_WEBPACK_IMPORTED_MODULE_0_react___default.a.createContext is not a function

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值