当前位置:   article > 正文

微信小程序图片懒加载【功能实现及运行原理】

微信小程序图片懒加载

因为项目需要就写了个懒加载,因为小程序不可以获取DOM,所以用下面的写法,如果各位码友有更好的办法欢迎评论。

废话不多说直接上代码

View模块代码

<view class="publicView">
  <view class="wxapp_index_view flex " wx:for="{{arrList}}" wx:for-index="index">
    <image class="opcityClass {{array[index] ? 'active' : ''}}" src="{{array[index] ? arrList[index].image : '/img/giao.jpg'}}"></image>
  </view>
</view>   
  • 1
  • 2
  • 3
  • 4
  • 5

Js模块代码

Page({

  /**
   * 页面的初始数据
   */
  data: {
    arrList: [{
        id: 0,
        image: 'https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1089874897,1268118658&fm=26&gp=0.jpg'
      },
      {
        id: 1,
        image: 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1819216937,2118754409&fm=26&gp=0.jpg'
      }, {
        id: 0,
        image: 'https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1089874897,1268118658&fm=26&gp=0.jpg'
      },
      {
        id: 1,
        image: 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1819216937,2118754409&fm=26&gp=0.jpg'
      }, {
        id: 0,
        image: 'https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1089874897,1268118658&fm=26&gp=0.jpg'
      },
      {
        id: 1,
        image: 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1819216937,2118754409&fm=26&gp=0.jpg'
      }, {
        id: 0,
        image: 'https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1089874897,1268118658&fm=26&gp=0.jpg'
      },
      {
        id: 1,
        image: 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1819216937,2118754409&fm=26&gp=0.jpg'
      }, {
        id: 0,
        image: 'https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1089874897,1268118658&fm=26&gp=0.jpg'
      },
      {
        id: 1,
        image: 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1819216937,2118754409&fm=26&gp=0.jpg'
      }, {
        id: 0,
        image: 'https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1089874897,1268118658&fm=26&gp=0.jpg'
      },
      {
        id: 1,
        image: 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1819216937,2118754409&fm=26&gp=0.jpg'
      },
    ],
    array: [false, false, false, false, false, false, false, false, false, false, false, false],
    damoHeight: '150',//demo高度
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    // 360 = 存放图片容器的模块 
    let _this = this;
    let arrayRi = _this.data.array;
    console.log(arrayRi)
    let num = Math.ceil(wx.getSystemInfoSync().windowHeight / 360);
    console.log(num);
    for (let i = 0; i < num; i++) {
      arrayRi[i] = true;
    };
    console.log(arrayRi);
    _this.setData({
      array: arrayRi
    })
  },

  // 滚动页面时触发该函数
  onPageScroll: function (e) {
    let _this = this;
    var _y = parseInt(e.scrollTop / _this.data.damoHeight);
    _this.data.array[_y + 1] = true;
    _this.setData({
      array: _this.data.array
    }); 
  }
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83

Css模块代码

.publicView {
  width: 100%;
  height: auto;
  min-height: 1000rpx;
  overflow: hidden;
}

.wxapp_index_view {
  width: 100%;
  height: 360rpx;
  background-color: rgb(238, 235, 235);
  margin-bottom: 20rpx;
}


.active{
  opacity: 1;
  transition: all 3s;
}

.wxapp_index_view image {
  width: 100%;
  height: 100%;
}

.flex {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30

先把代码给大家粘贴出来,省的大家先看我罗嗦的字,后看我的代码,哈哈哈~

运行原理

代码都给你了,啥运行原理的~
自己研究去吧,,,,哈哈哈哈 再见~

最终展示结果如下:
在这里插入图片描述
源代码已经放到【码云】上了

点击下载

小编从小白一步步成长,点滴记录,希望可以帮助到有需要的伙伴!!!

不忘初心,加油!!!

欢迎更多大佬在下方给出小编更多的好办法。

如果帮助到您,记得一键三连呢,感谢~

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/321264
推荐阅读
相关标签