我正在尝试使用webpack和webpack-dev-server在React组件中显示图像作为项目的一部分。
到目前为止,我已经完成了以下步骤:
采取了这些步骤后,webpack编译失败并显示“找不到模块”错误:
ERROR in [at-loader] ./src/components/App.tsx:4:26
TS2307: Cannot find module '../images/kitten-header.jpg'.
Run Code Online (Sandbox Code Playgroud)
我的文件夹结构如下:
/dist
/images
kitten-header.jpg
bundle.js
bundle.js.map
/node_modules
(content ignored for brevity)
/src
/components
App.tsx
/images
kitten-header.jpg
/styles
App.less
index.tsx
index.html
package.json
tsconfig.json
webpack.config.js
Run Code Online (Sandbox Code Playgroud)
我添加到webpack.config.js的新加载器是:
test: /\.(jpe?g|gif|png|svg)$/, loader: "file-loader?name=./images/[name].[ext]"
Run Code Online (Sandbox Code Playgroud)
我已经将图像文件导入了App.tsx中,如下所示:
import kittenHeader from '../images/kitten-header.jpg';
Run Code Online (Sandbox Code Playgroud)
...并在img标签中使用了导入,如下所示:
<img src={ kittenHeader } />
Run Code Online (Sandbox Code Playgroud)
注意:提供了webpack.config.js和App.tsx的全文,直到我更接近答案并意识到它们不相关为止(请参阅更新1)。
我假设我在导入的相对路径方面犯了一些非常琐碎的错误。可以想象,我尝试了多种选择。
谁能提供一些见识?
作为参考,由于我不断遇到与错误版本的Webpack有关的文章和问题,以下是我的版本:
显然,我将需要提供d.ts文件或使用require语句。
差不多好了...