码迷,mamicode.com
首页 > 其他好文 > 详细

如何使用小程序做到回到顶部的效

时间:2017-05-30 00:04:48      阅读:604      评论:0      收藏:0      [点我收藏+]

标签:com   test   实现   判断   小程序   无效   属性   不能   bottom   

      这里小程序有个组件是可以实现的,那就是scroll-view组件,他具有很多的属性,其中我们要利用到以下两个属性来处理:

scroll-top Number   设置竖向滚动条位置
bindscroll EventHandle   滚动时触发,event.detail = {scrollLeft, scrollTop, scrollHeight, scrollWidth, deltaX, deltaY}

      通过滚动触发事件,获取距离文档顶部的scrollTop值,当达到一定条件【>300】的时候,显示gotop层,针对这个层写点击事件,重新设置scroll-top值,偶然间发现设置scroll-top的一个bug,如果我下一次设置的值和本次scroll-top值是一样的,那么文档并不会有任何动作。因此我的做法是在0和1之间切换设置,具体做法如下:

<scroll-view style="height: 100%;" scroll-y="true" scroll-top="{{scrollTop.scroll_top}}" bindscroll="scrollTopFun">  
<view style="height: 11111rpx; border: solid 1px red;">  
123456  
----{{test}}  
</view>  
</scroll-view>  
  
<view style="position: absolute; bottom: 50rpx; right: 30rpx; width: 120rpx; height: 120rpx; border: solid 1px green;" wx:if="{{scrollTop.goTop_show}}" catchtap="goTopFun"></view>  

  JS:

Page({
  data: {

    test: "",
    scrollTop: {
      scroll_top: 0,
      goTop_show: false
    }
  },
  scrollTopFun: function (e) {
    console.log(e.detail);
    if (e.detail.scrollTop > 300) {//触发gotop的显示条件  
      this.setData({
        ‘scrollTop.goTop_show‘: true
      });
      console.log(this.data.scrollTop)
    } else {
      this.setData({
        ‘scrollTop.goTop_show‘: false
      });
    }
  },
  goTopFun: function (e) {
    var _top = this.data.scrollTop.scroll_top;//发现设置scroll-top值不能和上一次的值一样,否则无效,所以这里加了个判断  
    if (_top == 1) {
      _top = 0;
    } else {
      _top = 1;
    }
    this.setData({
      ‘scrollTop.scroll_top‘: _top
    });
    console.log("----");
    console.log(this.data.scrollTop)
  }
})  

  

 

最终效果如下:

技术分享

 

如何使用小程序做到回到顶部的效

标签:com   test   实现   判断   小程序   无效   属性   不能   bottom   

原文地址:http://www.cnblogs.com/mmykdbc/p/6919350.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!