react里的require失效怎么办

藏色散人
藏色散人原创
2023-01-04 16:43:241097浏览

react里的require失效是因为require返回一个ES模块而不是字符串,其解决办法就是通过“require('../path/to/image.jpg').default;”方式引入即可。

本教程操作环境:Windows10系统、react18.0.0版、Dell G3电脑。

react里的require失效怎么办?

react项目中require引入图片无效的原因及解决方案

原因

如果使用create-react-app和require导入图像,require返回一个ES模块而不是字符串。这是因为在file-loader中,esModule选项是默认启用的。

解决方案

const image = require('../path/to/image.jpg').default;
// OR
import image from '../path/to/image.jpg';

require与import区别

require是commonjs的规范,在node中实现的api;import是es的语法,由编译器处理。所以import可以做模块依赖的静态分析,配合webpack、rollup等可以做treeshaking。

commonjs导出的值会复制一份,require引入的是复制之后的值(引用类型只复制引用),es module导出的值是同一份(不包括export default),不管是基础类型还是应用类型。

写法上有差别,import可以使用import * 引入全部的export,也可以使用import aaa, {bbb}的方式分别引入default和非default的export,相比require更灵活。

推荐学习:《react视频教程

以上就是react里的require失效怎么办的详细内容,更多请关注php中文网其它相关文章!

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。