返回

专注连锁门店会员营销管理系统

线上+线下+进销存+收银+会员
HiShop > Hi小程序 > 小程序开发 > 开发实例 >

小程序设置默认图片、错误加载图片

2020-09-27 作者:黄珊

  小程序设置默认图片、错误加载图片的实现效果:

小程序设置默认图片、错误加载图片

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

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

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

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

  wxml:

  小程序设置默认图片、错误加载图片

  说明:

  imgList: 图片数据源列表,需要在data中定义初始数据,或者从接口动态获取数据;

  errorFunction: 图片加载错误绑定的事件,错误图片替换为默认图片主要在这里操作;

  data-errorimg: 错误图片索引数据,需要在errorFunction中用以记录错误图片对应的位置;

  如果图片地址为空,是不会触发binderror的,所以就直接对图片地址做判断,如果为空,则替换为默认图片。

小程序设置默认图片、错误加载图片

  js:

  data: {

  imgList:"", //图片列表,动态获取

  defaultImg: "../../../assets/img/defaultImg.png", //默认图片

  },

  ......

  省略图片数据源获取代码

  ......

  /**

  * 图片加载错误触发的事件

  */

  errorFunction: function (e) {

  if(e.type=="error"){

  var errorImgIndex = e.target.dataset.errorimg //获取错误图片循环的下标

  var imgList= this.data.imgList        //将图片列表数据绑定到变量

  imgList[errorImgIndex] = this.data.defaultImg //错误图片替换为默认图片

  this.setData({

  evaluteUserPic: evaluteUserPic

  })

  }

  }

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

HiShop小程序工具提供多类型商城/门店小程序制作,可视化编辑 1秒生成5步上线。通过拖拽、拼接模块布局小程序商城页面,所看即所得,只需要美工就能做出精美商城。

更多小程序开发案例,尽在:http://www.hishop.com.cn/xiaocx/kaifa.html 

线上+线下+进销存+收银+会员门店零售管理好帮手

  • 极速收银管理

    门店能实现快速收银,提升门店经营效率。

  • 进销存管理

    系统自带进销存管理,更好管理库存销售。

  • 软硬件一体化

    配备收银硬件一站式整体服务。

收 银 会员管理 库存管理 商品管理 交接班 数据报表 营销促单 售后处理 多种收款

获取报价
【本站声明】

1、本网站发布的该篇文章,目的在于分享电商知识及传递、交流相关电商信息,以便您学习或了解电商知识,请您不要用于其他用途;
2、该篇文章中所涉及的商标、标识的商品/服务并非来源于本网站,更非本网站提供,与本网站无关,系他人的商品或服务,本网站对于该类商标、标识不拥有任何权利;
3、本网站不对该篇文章中所涉及的商标、标识的商品/服务作任何明示或暗示的保证或担保;
4、本网站不对文章中所涉及的内容真实性、准确性、可靠性负责,仅系客观性描述,如您需要了解该类商品/服务详细的资讯,请您直接与该类商品/服务的提供者联系。

推荐文章

门店系统 获取报价 立即咨询 免费试用