前端页面图片加载失败如何处理

换成默认背景图片或隐藏

方法有多种:

1.首先说我用的,看代码

//页面图片加载失败时 默认显示统一处理

document.addEventListener("error", function (e) {

    var elem = e.target;

    if (elem.tagName.toLowerCase() == "img") {

        elem.src = "/image/General/errorDefault.png";

    }

}, true);

这种写法的好处,可以监听到动态js添加进来的元素,有些人可能会用jq的事件代理delegate或者on(我没有实现,开始以为我代理的不对,后来知道是error事件不支持冒泡),最好先将默认图片预加载:

var imgObj = new Image();

imgObj.src = '默认路径';

如果默认图片也加载失败,会出现闪烁并且不断触发error方法,陷入死循环。

解决办法就是定义全局变量 num 每触发一次error num++,当num大于某一阀值的时候停止 定义error = null;关闭监听,并且显示alt的内容,做到向下兼容。

2.普通的方法:

$("img").on("error", function () {
    $(this).attr("src", "../img/img.jpg");
});

不支持动态添加的元素。

而且也会陷入死循环

3.另一种是可以避免陷入死循环的

$("img").one("error", function(e){     $(this).attr("src", "default.gif");});
4.还有一种直接在html标签中添加:

<img src="/image.gif" οnerrοr='this.src="default.gif" />
————————————————
版权声明:本文为CSDN博主「非渔驿站」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_38500689/article/details/79563631

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值