首先,来看下效果图(演示一下图片正常加载与加载失败时的效果) 在线体验地址:https://hxkj.vip/demo/vueImgOnerror/ 一.常规方法解决 我们都知道,img标签支持onerror事件,在装载文档或图像的过程中如果发生了错误,就会触发onerror事件.可以使用一张提示错误的图片代替显示不了的图片. 例如这样使用: <img src="images/logo.png" onerror="javascript:this.src='images/…
当图片加载失败时更换图片. <!DOCTYPE html> <meta charset="UTF-8"> <img src="http://www.qq.com/favicon.ico" /> 加载成功 <hr> <img src="http://www.qq.com/favicon" onerror="var img = event.srcElement; img.src = 'h…
原理就是给img绑定error事件,替换原有的src地址. 首先在data中创建一个defaultImg(随便起的),里面的值是该默认图片的地址: 在html页面的img标签上绑定该属性 这样默认图片就设置好了: 这样做的好处就是可以提高用户体验,而图片的alt属性,是在图片显示失败后出现的文字,像下图所示,但是这样的用户体验不高: 像后台管理系统中,如果是这样或者是有一个默认封面的话,会感觉很舒服:…
问题的引出是这样的,在一个项目中有大量的页面主体是table做数据展示,所以就封装了一个table的组件,提供动态渲染的方案.有个问题是数据类型中有图片,对于图片的加载失败我们需要做容错.一般我们的思路都是对img绑定error事件,替换该图片为一个默认的图片.但是error事件是不会冒泡的,我们渲染是动态的,我们不能delegate事件到body上.如果将处理写在js里,那么每次渲染的时候都要去给图片绑定error事件,写在模板里拼接(内联事件)又会很麻烦(我采取的方案是用户编写基本th,td…
<img :src="bak" @error="imgLoadError()" alt="bak"> data(){ return:{ bak: require('引用图片'), } } methods:{ imgLoadError () { this.$ajax.$post("接口", { //this.$ajax.$post 为自己封装的请求方式 errorType: ''//反馈类型 }, msg =>…
为图片指定加载失败时显示默认图片,js输出的img对象,onerror是事件,不是属性,所以这样写是不起作用的: var img = $(document.createElement("IMG"));     img.attr({         "src": imgs[idx],         "alt": tips[idx],         "onerror":"this.src='" + NoPi…
前言 图片加载优化对于一个网站性能好坏起着至关重要的作用.所以我们使用Vue来操作一波.备注 以下的优化一.优化二栏目都是我自己封装在Vue的工具函数里,所以请认真看完,要不然直接复制的话,容易出错的.资源 Vue.js Element UI 优化一:图片加载动画 只有当图片加载完成后才可以显示图片,加载动画结束.我们使用Element UI中的loading组件来用作加载的动画.假设一个变量loading初始值为true,当图片加载完时为false. // 图片加载 imgLoad:(src)…
纯css解决方案: <img src="broken.png" alt=""> img { position: relative; } img:after { content: url('替代圖片'); display: block; position: absolute; // 底下是故意要填满并且背景填滿擋住底下那個很醜的加載失敗圖片(字体) z-index:; top:; left:; width: 100%; height: 100%; back…
[第1103期]vue 自定义指令的魅力 点点 前端早读课 2017-11-08 前言 很多事情不能做过多的计划,因为计划赶不上变化.今日早读文章由富途@点点翻译分享. 正文从这开始- 在你初次接触一个新的Javascript框架时,会像第一次进糖果店的孩子一样.给啥拿啥,而更直接点,有些东西可以让你更容易成为一个开发者.不可避免的是,我们在用框架时都会有一个同感,就是总有些场景是框架不能帮我们完成的. Vue框架的漂亮之处在于它的功能非常强大,虽然这个框架的指令不够面面俱到,但也能在开发上助你…