当前位置:微信小程序开发 > 小程序资讯 > 小程序开发教程 > 微信小程序判断页面滑动方向

微信小程序判断页面滑动方向

2018-09-05 10:24 来源: 霸界科技

摘要:微信小程序在开发过程中,我们可能会需要判断小程序页面滚动方向是向上,还是向下,那么该如何判断呢,下面小编为大家解答。 ...

期权保本理财
  微信小程序在开发过程中,我们可能会需要判断小程序页面滚动方向是向上,还是向下,那么该如何判断呢,下面小编为大家解答。
 
微信小程序判断页面滑动方向
 
  微信小程序判断页面滑动方向
 
  解决方案
 
  1.用到微信小程序API
 
  获取页面实际高度 nodesRef.boundingClientRect([callback])
 
  监听用户滑动页面事件onPageScroll。
 
  2.获取页面实际高度
 
  <!--WXML-->
 
  <view id="box">
 
  <view class="list" wx:for="{{List}}" wx:key="List{{index}}">
 
  <image mode='aspectFill' class='list_img'  src="{{item.imgUrl}}"  ></image>
 
  </view>
 
  </view>    /* JS */
 
  // 封装函数获取ID为box的元素实际高度
 
  getScrollHeight: function() {
 
  wx.createSelectorQuery().select('#box').boundingClientRect((rect) => {
 
  this.setData({
 
  scrollHeight: rect.height
 
  })
 
  console.log(this.data.scrollHeight)
 
  }).exec()
 
  },
 
  // 假设数据请求
 
  getDataList: function() {
 
  wx.request({
 
  url: 'test.php', //仅为示例,并非真实的接口地址
 
  success: function(res) {
 
  // 如果该元素下面的数据是动态获取的,此方法在wx.request请求成功的回调函数中调用
 
  this.getScrollHeight()
 
  }
 
  })
 
  },
 
  3.监听用户滑动页面事件
 
  //监听用户滑动页面事件
 
  onPageScroll: function(e) {
 
  if (e.scrollTop <= 0) {
 
  // 滚动到最顶部
 
  e.scrollTop = 0;
 
  } else if (e.scrollTop > this.data.scrollHeight) {
 
  // 滚动到最底部
 
  e.scrollTop = this.data.scrollHeight;
 
  }
 
  if (e.scrollTop > this.data.scrollTop || e.scrollTop >= this.data.scrollHeight) {
 
  //向下滚动
 
  console.log('向下 ', this.data.scrollHeight)
 
  } else {
 
  //向上滚动
 
  console.log('向上滚动 ', this.data.scrollHeight)
 
  }
 
  //给scrollTop重新赋值
 
  this.setData({
 
  scrollTop: e.scrollTop
 
  })
 
  },
分享到:
最新评论

网友:

验证码: 点击我更换图片

联系我们

业务咨询:15918761088

招商咨询:15918761088(微信同号)

周一至周五 9:30-18:30

公司地址:广州市海珠区昌岗中路166号富盈国际大厦2505室

官方微信 官方微博

Copyright © 2018 www.keji168.com 广州霸界网络科技有限公司版权所有 粤ICP备18083764号-1

客服
套餐咨询,合作细节等
在线客服
电话咨询
159-1876-1088