小程序不支持h5中的onerrorimg,只开放了binderror属性,当错误发生时,会发布到 AppService,事件对象event.detail = {errMsg: 'something wrong'}。 网上查了下,没有什么好的解决方法,找了几个案例结果都没有实现想要的效果。 结合前边看过的案例,大部分都是采用修改数据源将错误图片替换为默认图片的,但是有好多代码都没贴全,以致不好理解。 下面就根据自己遇到的情况对图片为空、图片路径错误的情况进行了处理,相关代码如下,相关数据都有说明: wxml:
说明: imgList: 图片数据源列表,需要在data中定义初始数据,或者从接口动态获取数据; errorFunction: 图片加载错误绑定的事件,错误图片替换为默认图片主要在这里操作; data-errorimg: 错误图片索引数据,需要在errorFunction中用以记录错误图片对应的位置; 如果图片地址为空,是不会触发binderror的,所以就直接对图片地址做判断,如果为空,则替换为默认图片。 js:
备注:使用这种方法,是需要将图片数据源放在data中的,这样才可以在 binderror 的事件中进行数据的替换,不可以直接在wxml中调用接口的数据。 |