微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JavaScript通过使用onerror设置默认图像显示代替alt

JavaScript代码

rush:js;">  //图像加载出错时的处理 function errorImg(img) { img.src = "图片.jpg"; img.onerror = null; }

HTML代码

rush:js;">

为了美观当网页图片不存在时不显示叉叉图片

当在页面显示的时候,万一图片被移动了位置或者丢失的话,将会在页面显示一个带X的图片,很是影响用户的体验。即使使用alt属性给出了”图片XX”的提示信息,也起不了多大作用。 其实,可以这样处理:当图片不存在的时候,会触发onerror事件,我们可以在该事件中做一下补救的工作,比如:

1、让这个图片元素隐藏:

rush:js;"> 为了美观当网页图片不存在时不显示叉叉图片 src="图片URL地址" alt="图片XX" onerror="this.style.display='none'"/>

2、用认的图片替换:

rush:js;"> 为了美观当网页图片不存在时不显示叉叉图片 src="图片URL地址" alt="图片XX" onerror="this.src='图片URL地址'"/>

注意:如果使用不当,在IE内核的浏览器下会造成死循环。比如:当【图片URL地址】也加载不成功(比如网速比较慢的时候)或不存在的话,就会反复的加载,最后造成堆栈溢出错误

因此, 需要用下面两种方法解决

a、更改 onerror 代码为其它处理方式或者确保 onerror 中的图片足够小,并且存在。

b、控制onerror事件只触发一次,需要增加这句话:this.onerror=null; 增加后如下:

rush:js;"> 为了美观当网页图片不存在时不显示叉叉图片 src="图片URL地址" alt="图片XX" onerror="this.src='图片URL地址;this.onerror=null'"/>

经测试,上面的方法在IE各个版本及谷歌、火狐浏览器中都支持

原文地址:https://www.jb51.cc/js/49891.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐