zoukankan      html  css  js  c++  java
  • 小程序处理图片加载失败的问题

    今天在开发西奥程序过程中,遇到一个问题,图片加载失败的时候页面,显示空白比较难看,需求是希望再图片加载失败的时候,显示加载失败的图片,刚开始也查了一番,没有找到类似的方法,最终自己翻看MDN看到了img的onerror属性,抱着测试的心里,最终解决了自己的问题;在这里记录下来,希望能帮到大家。

    下面是处理前和处理后的效果:

    <view class="container">
      <block wx:for="{{imgUrls}}" wx:key="index">
        <image src="{{item}}" onerror="imgOnerror" data-idx="{{index}}"></image>
      </block>
    </view>
    .container {
      display: flex;
      flex-wrap: wrap;
      padding: 30rpx 30rpx 10rpx;
      box-sizing: border-box;
    }
    .container > image {
       156rpx;
      height: 156rpx;
      background: pink;
      margin: 0 20rpx 20rpx 0;
      display: block;
    }
    .container > image:nth-of-type(4n) {
      margin-right: 0;
    }
    

      

    Page({
    
      /**
       * 页面的初始数据
       */
      data: {
        imgUrls: [
          'https://images.unsplash.com/photo-1551334787-21e6bd3ab135?w=640',
          'https://images.unsplash.com/photo-1551214012-84f95e060dee?w=640',
          'https://images.unsplash.com/photo-1551214012-84f95e060dee?w=640',
          'https://images.unsplash.com/photo-1551446666-142875a901a1?w=770',
          'https://images.unsplash.com/photo-1551334787-21e6bd3ab135?w=640',
          'https://images.unsplash.com/photo-1551334787-21e6bd3ab135?w=640',
          'https://images.unsplash.com/photo-1551214012-84f95e060dee?w=640',
          'https://images.unsplash.com/photo-1551446666-142875a901a1?w=880',
        ],  //第四和第八张图片是无效的
      },
    
      /**
       * 图片加载失败处理函数
       */
      imgOnerror(e) {
        var idx = e.currentTarget.dataset.idx;
        console.log(idx)
        var _imgUrls = this.data.imgUrls;
        for (var i = 0; i < _imgUrls.length; i++) {
          if (i == idx) {
            _imgUrls[i] = 'https://images.unsplash.com/photo-1551446591-142875a901a1?w=640'
          }
        }
        this.setData({
          imgUrls: _imgUrls
        })
      },
    
      /**
       * 生命周期函数--监听页面加载
       */
      onLoad: function (options) {
    
      },
    
      /**
       * 生命周期函数--监听页面初次渲染完成
       */
      onReady: function () {
    
      },
    
      /**
       * 生命周期函数--监听页面显示
       */
      onShow: function () {
    
      },
    
      /**
       * 生命周期函数--监听页面隐藏
       */
      onHide: function () {
    
      },
    
      /**
       * 生命周期函数--监听页面卸载
       */
      onUnload: function () {
    
      },
    
      /**
       * 页面相关事件处理函数--监听用户下拉动作
       */
      onPullDownRefresh: function () {
    
      },
    
      /**
       * 页面上拉触底事件的处理函数
       */
      onReachBottom: function () {
    
      },
    
      /**
       * 用户点击右上角分享
       */
      onShareAppMessage: function () {
    
      }
    })
  • 相关阅读:
    使用c#读取/解析二维码
    MVVM中的RelayCommand与AsyncCommand
    MVVM模式下的OpenFileDialog
    集成Source Monitor至VS中
    [转]异步command的实现
    使用Messenger实现MVVM的对话框弹出
    使用NPOI访问、控制Excel
    win11更新
    Codeforces Round #749 总结
    Codeforces Round #697 (Div. 3)
  • 原文地址:https://www.cnblogs.com/rzsyztd/p/11278137.html
Copyright © 2011-2022 走看看