• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

微信小程序开发——设置默认图片、错误加载图片 - 逍遥云天 ...

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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

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

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

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

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

wxml:

<image src=\'{{imgList[index]==""?defaultImg:imgList[index]}}\'  binderror="errorFunction" data-errorimg="{{index}}" />
说明:     
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中调用接口的数据。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap