解决typescript + react + url-loader 找不到图片问题

最近自己在撸一个小项目,基于react + react-router + typescript + mobx + axios 的一个购物车网站。在登陆页面想添加一个漂亮小姐姐作为引导(其实就是皮,三玖天下第一)

但是在引用本地图片的时候,报错

[ts] 找不到模块“../../../public/images/san.jpeg”。
复制代码

在网上找了很多文章,终于用蹩脚的英语在google上找到了答案和解决方法(google大法好啊 T.T)。

只在typescript中。ts、js文件是相关的,如果你试着从文件导入xxx.png,typescript就不知道如何处理它,Webpack配置不使用ts。 所以我们要把图片格式以申明为模块

  • 首先添加文件 images.d.ts 并添加如下代码
declare module '*.svg'
declare module '*.png'
declare module '*.jpg'
declare module '*.jpeg'
declare module '*.gif'
declare module '*.bmp'
declare module '*.tiff'
复制代码
  • 然后 在图片引入的地方使用*读取并且重命名
import * as loginImg from '../../../public/images/san.jpeg';
复制代码

这样vsCode就不报错,并且可以启动项目了!!!

这样漂亮(wo)小(lao)姐姐(po)就显示出来了

简直猛男落泪啊!!!

感谢大佬的文章

github.com/Microsoft/T…

stackoverflow.com/questions/3…

如果各位大神有别的解决方法也希望告诉小老弟我,嘿嘿。

转载于:https://juejin.im/post/5c5f87c36fb9a049dd80c0d3

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值