微信小程序开发设置默认图片、错误加载图片

小程序不支持h5中的onerrorimg,只开放了binderror属性,当错误发生时,会发布到 AppService,事件对象event.detail = {errMsg: 'something wrong'}。

网上查了下,没有什么好的解决方法,找了几个案例结果都没有实现想要的效果。

微信小程序开发设置默认图片、错误加载图片

结合前边看过的案例,大部分都是采用修改数据源将错误图片替换为默认图片的,但是有好多代码都没贴全,以致不好理解。

下面就根据自己遇到的情况对图片为空、图片路径错误的情况进行了处理,相关代码如下,相关数据都有说明:

wxml:


  1. <image src='{{imgList[index]==""?defaultImg:imgList[index]}}' binderror="errorFunction" data-errorimg="{{index}}" />

说明:     
imgList: 图片数据源列表,需要在data中定义初始数据,或者从接口动态获取数据;
errorFunction: 图片加载错误绑定的事件,错误图片替换为默认图片主要在这里操作;
data-errorimg: 错误图片索引数据,需要在errorFunction中用以记录错误图片对应的位置;
如果图片地址为空,是不会触发binderror的,所以就直接对图片地址做判断,如果为空,则替换为默认图片。

js:


  1. data: {
  2. imgList:"", //图片列表,动态获取
  3. defaultImg: "../../../assets/img/defaultImg.png", //默认图片
  4. },
  5. ......
  6. 省略图片数据源获取代码
  7. ......
  8. /**
  9. * 图片加载错误触发的事件
  10. */
  11. errorFunction: function (e) {
  12. if(e.type=="error"){
  13. var errorImgIndex = e.target.dataset.errorimg //获取错误图片循环的下标
  14. var imgList= this.data.imgList        //将图片列表数据绑定到变量
  15. imgList[errorImgIndex] = this.data.defaultImg //错误图片替换为默认图片
  16. this.setData({
  17. evaluteUserPic: evaluteUserPic
  18. })
  19. }
  20. }

备注:使用这种方法,是需要将图片数据源放在data中的,这样才可以在 binderror 的事件中进行数据的替换,不可以直接在wxml中调用接口的数据。


【本站声明】
  1、本站文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如果有侵权请立即联系。
  2、本网站不对文章中所涉及的内容真实性、准确性、可靠性负责,仅系客观性描述,如您需要了解该类商品/服务详细的资讯,请您直接与该类商品/服务的提供者联系。


KESION 科汛软件

KESION 科汛软件是国内领先的在线教育软件及私域社交电商软件服务提供商,长期专注于为企业提供在线教育软件及社交电商SaaS平台解决方案。
公司核心产品云开店SaaS社交电商服务平台、在线教育SaaS服务平台、教育企业数字化SaaS云平台、企微营销助手、私有化独立部署品牌网校和在线教育咨询等。

KESION 不断通过技术创新,提供产品和服务,助力企业向数字化转型,通过科技驱动商业革新,让商业变得更智慧!



▼点击进入科汛官网了解更多



上/下篇
  • selectorQuery.in,选择第一个匹配选择器selector的节点

  • 微信小程序改变小程序码中间logo的方法

换一换相关推荐
精选内容
热点精选