图片加载失败的正确处理[通俗易懂]

图片加载失败的正确处理[通俗易懂]<imgsrc=”http://imgsrc.baidu.com/forum/pic/item/fd1f4134970a304e16d3176ad3c8a786c8175ca8.jpg”/>对于这样一段代码来讲,如果该图片加载成功,那么界面上会显示图片,如果由于一些原因导致图片加载失败,会出现这样的图标。在正常的项目中,标签的src是后端返回的路径,如果图片加载不出来,显示上…

大家好,又见面了,我是你们的朋友全栈君。

<img src="http://imgsrc.baidu.com/forum/pic/item/fd1f4134970a304e16d3176ad3c8a786c8175ca8.jpg" />

对于这样一段代码来讲,如果该图片加载成功,那么界面上会显示图片,如果由于一些原因导致图片加载失败,会出现这样的图标。在这里插入图片描述
在正常的项目中,标签的src是后端返回的路径,如果图片加载不出来,显示上面的图标肯定不美观,这时会考虑选择默认的图片,就时候考虑用到img的onerror事件。
本项目中默认图片为:
图片加载失败的正确处理[通俗易懂]
项目中代码为:

<img class="appPic" src="{opts.data.pic}" onerror="{picError}">

js代码为:

self.defaultPic = '/headImg?name=app-default-logo.png';
self.picError = function (e) {
     e.target.src = self.defaultPic;
 };

如果后端返回的路径信息传到前端,图片没有加载成功,正常应该显示默认的图片,如果默认的图片也加载成功,那么picError事件就不再执行(也就是picError事件只执行一次)。
但是这种写法会出现一个问题:如果后端返回的路径信息传到前端,图片没有加载成功,正常应该显示默认的图片,但是如果默认的图片恰巧也没有加载成功,就会出现默认的图片无限加载的情况。
比如,本项目中,img的html代码为:

<img class="appPic" src="/headImg?name=8567250ff9a369ce33d21780b6ce7e42">

当图片加载到页面上,src会自动和服务端的域名拼接,如:

http://qy.com:9000/headImg?name=8567250ff9a369ce33d21780b6ce7e42

那么就会出现默认的图片无限加载的情况,导致浏览器卡死:
图片加载失败的正确处理[通俗易懂]
那么如何在加载默认图片时,只加载一次呢?如果默认图片不显示,就不再加载,显示图片加载失败的图片呢?在这里插入图片描述
只需要将原来的代码修改为:

self.defaultPic = '/headImg?name=app-default-logo.png';
self.picError = function (e)  {
  if (!(e.target.src.endsWith(self.defaultPic))) {
       e.target.src = self.defaultPic;
   }
};

思考一下:如果希望错误次数不是为1而是为2,3…应该怎么解决呢?

self.defaultPic = '/headImg?name=app-default-logo.png';
self.picError = function (e) {
	// 失败加载一次
	// if (!(e.target.src.endsWith(self.defaultPic))) {
	//     e.target.src = self.defaultPic;
	// }
	// 失败加载三次
	const target = e.target;
	const errorTimes = self.errorTimes || 0;   // 以当前失败的次数,默认为0
	const allTimes = 3; // 总失败次数,此时设定为3
	   if (errorTimes >= allTimes) {
	       // target.src = 'data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7';
	       return;
	   } else {
	       self.errorTimes = errorTimes + 1;
	       target.src = self.defaultPic;
	   }
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137924.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 关于离线缓存Application Cache /使用 manifest文件缓存

    ApplicationCache的配置文件首先需要在服务器上建立一个文件,里面的内容确定了哪些文件需要缓存,哪些文件不需要,如果资源无法访问会使用什么页面等这个文件一般为.appcache类型,称为缓存清单(cachemanifest)文件,一个完整的缓存清单文件如下:CACHEMANIFEST#versionxx.xx.xxCACHE:needBeCached.pn…

    2022年4月11日
    52
  • pycharm怎么初始化设置_pycharm安装之后的设置

    pycharm怎么初始化设置_pycharm安装之后的设置pycharm的初始设置恢复pycharmpycharm的配置信息是保存在用户目录下.PyCharm***.*目录下的,***.*表示当前使用的pycharm的版本号如果要回复pycharm的初始设置,可以按照以下步骤进行 关闭正在运行的pycharm 删除pycharm的配置信息目录 rm-r~/.PyCharm16.3 重新启动pycharm(选择没有配置信息选项 ) 选择许可协议新建/打开一个pychar

    2022年8月27日
    1
  • HTML中空格_如何去掉word中的空格

    HTML中空格_如何去掉word中的空格1. 空格符大  家  好!显示效果为:大家好!2.p标签使用空两格百度地图API功能百度地图API功能效果如下:3.span标签空格百度地图API功能百度地图API功能效果如下:4.word-spacing属性,Happynewyear!效果:![在这里插入图片描述](https://img-blog….

    2022年9月28日
    0
  • Python之用虚拟环境隔离项目,并重建依赖关系

    下面将以安装django和mysqlclient介绍如何用虚拟环境隔离项目,并重建依赖关系。操作系统:windows10;python版本:python3.71.安装python虚拟环境(1)

    2021年12月30日
    38
  • Squid 代理服务之透明代理服务器架构搭建

    文章目录1.服务器配置2.Squid服务器部署2.1修改Squid配置文件2.2开启路由转发,实现本机中不同网段的地址转发2.3修改防火墙规则3.客户端访问测试1.服务器配置服务器主机名IP地址主要软件Squid服务器squid_server内网ens33:192.168.10.20|外网ens37:10.0.0.100squidWeb服务器web_server10.0.0.200apacheWin10客户端192.1

    2022年4月7日
    213
  • Redhat的yum配置步骤

    Redhat的yum配置步骤Redhat的yum配置RedhatLinux是免费的操作系统,但是里面的yum服务是收费的,有的时候我们安装软件必须从yum上面安装。虽然Redhat的yum是收费的,但我们可以使用CentOS

    2022年7月4日
    22

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号