zoukankan      html  css  js  c++  java
  • 微信小程序开发——设置默认图片、错误加载图片

    小程序不支持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中调用接口的数据。

  • 相关阅读:
    time 类
    案例:手动输入一个字符串,所有字符反转,大小写相互转
    案例:使用列表年月日 计算这个日期是这一天的多少天
    用python输出1-100之间所有的质数
    案例:手动输入一个字符串,打散放进一个列表,小写字母反序 大写字母保持不变
    安装数据库教程
    PHP use MySQLi
    PHP logging
    Vagrant
    Flask基础
  • 原文地址:https://www.cnblogs.com/xyyt/p/8528365.html
Copyright © 2011-2022 走看看