原因
如果使用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更灵活。