• 技术文章 >微信小程序 >小程序开发

    利用scroll-view组件实现小程序回到顶部特效

    王林王林2021-02-22 09:36:05转载657

    我们在浏览网页的时候,经常会使用到一键回到顶部的功能,使用这个功能可以让我们非常方便地回到网页顶部。尤其是一些比较长的网页,如果没有这个功能,简直让人无法想象。那么在小程序中该如何实现这个功能呢?

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

    a97a722201c8bc13bbe15e0e5042576.png

    通过滚动触发事件,获取距离文档顶部的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)
      }
    })

    最终效果图:

    be2b7c5e853a88468b7f02c37deb695.png

    相关推荐:小程序开发教程

    以上就是利用scroll-view组件实现小程序回到顶部特效的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:博客园,如有侵犯,请联系admin@php.cn删除
    上一篇:小程序该如何正确调用后端接口 下一篇:如何在小程序页面内进行转发操作
    Web大前端开发直播班

    相关文章推荐

    • css实现快速回到顶部效果• 原生JS如何实现回到顶部效果?(详解)• ai顶部属性栏不见了怎么解决?• ps的顶部菜单栏没了怎么办

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网