The require in react fails because require returns an ES module instead of a string. The solution is to introduce it through "require('../path/to/image.jpg').default;" That’s it.
The operating environment of this tutorial: Windows 10 system, react18.0.0 version, Dell G3 computer.
What should I do if require in react fails?
The reasons and solutions for invalid images introduced by require in the react project
Cause
If you use create-react-app and require to import Image, require returns an ES module instead of a string. This is because in file-loader, the esModule option is enabled by default.
Solution
const image = require('../path/to/image.jpg').default; // OR import image from '../path/to/image.jpg';
The difference between require and import
require is the specification of commonjs, the API implemented in node; Import is the syntax of es and is processed by the compiler. Therefore, import can do static analysis of module dependencies, and can do treeshaking with webpack, rollup, etc.
The value exported by commonjs will be copied. require introduces the copied value (reference types only copy the reference). The value exported by es module is the same (excluding export default), regardless of the basic type. or application type.
There are differences in writing methods. For import, you can use import * to introduce all exports, or you can use import aaa, {bbb} to introduce default and non-default exports respectively, which is more flexible than require.
Recommended learning: "react video tutorial"
The above is the detailed content of What to do if require in react fails. For more information, please follow other related articles on the PHP Chinese website!