【webpack】img[src]图片加载遇坑记

问题描述
  • <img src="../assets/imgs/logo-qq.svg" alt="here is a logo"/>时,无法加载图片
//index.js
ReactDOM.render(
    <>
    <img src="../assets/imgs/logo-qq.svg" alt="here is a logo"/> 
    </>,
    document.querySelector("#root")
)

1在这里插入图片描述

  • background-image:url(../assets/imgs/logo-qq.svg)时,可以加载图片
import "./index.css";
ReactDOM.render(
    <>
    <span id="logo"></span>
    </>,
    document.querySelector("#root")
)
#logo{
    background-image:url(../assets/imgs/logo-qq.svg);
    background-repeat: no-repeat;
    display: inline-block;
    width: 32px;
    height: 32px;
}

14

问题分析

webpack递归解析依赖的过程中,没有将img[src]引用的图片计入依赖项。

解决方法

如果必须使用img[src]来引用图片的话,可以采用如下方式:

import logo from "../assets/imgs/logo-qq.svg";
ReactDOM.render(
    <>
    <img src={logo} alt="here is a logo"/> 
    </>,
    document.querySelector("#root")
)

源码

参考文档

url-loader不能处理html中引入的图片问题的解决方案
html-withimg-loader

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值