欢迎光临,了解微信小程序开发,就上易用通!

微信小程序实例:跳转到顶部实例

发布:2018-01-25 11:02浏览: 来源:网络 作者:tianshu

总所周知,小程序不能操作dom,那么我们要怎么实现在页面滚动到一定条件的时候,显示gotop图标,点击后跳转到页面的顶部呢?

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

 

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


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

如下:
  1. <scroll-view style="height: 100%;" scroll-y="true" scroll-top="{{scrollTop.scroll_top}}" bindscroll="scrollTopFun">  
  2. <view style="height: 11111rpx; border: solid 1px red;">  
  3. 123456  
  4. ----{{test}}  
  5. </view>  
  6. </scroll-view>  
  7.   
  8. <view style="position: absolute; bottom: 50rpx; right: 30rpx; width: 120rpx; height: 120rpx; border: solid 1px green;" wx:if="{{scrollTop.goTop_show}}" catchtap="goTopFun"></view>
  1. Page({  
  2.   data:{  
  3.   
  4.     test:"",  
  5.     scrollTop: {  
  6.       scroll_top: 0,  
  7.       goTop_show: false  
  8.     }  
  9.   },  
  10.   scrollTopFun: function(e){  
  11.     console.log(e.detail);  
  12.     if(e.detail.scrollTop > 300){//触发gotop的显示条件  
  13.       this.setData({  
  14.         'scrollTop.goTop_show': true  
  15.       });  
  16.       console.log(this.data.scrollTop)  
  17.     }else{  
  18.       this.setData({  
  19.         'scrollTop.goTop_show': false  
  20.       });  
  21.     }  
  22.   },  
  23.   goTopFun: function(e){  
  24.     var _top=this.data.scrollTop.scroll_top;//发现设置scroll-top值不能和上一次的值一样,否则无效,所以这里加了个判断  
  25.     if(_top==1){  
  26.       _top=0;  
  27.     }else{  
  28.       _top=1;  
  29.     }  
  30.     this.setData({  
  31.       'scrollTop.scroll_top': _top  
  32.     });  
  33.     console.log("----");  
  34.     console.log(this.data.scrollTop)  
  35.   }  
  36. })  

最终演示效果如下:


微信小程序实例:跳转到顶部实例(图1) 








免责声明:本站所有文章和图片均来自用户分享和网络收集,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系网站客服处理。