zoukankan      html  css  js  c++  java
  • vue-scroller记录滚动位置

    问题描述:

      列表页进入详情页,或者tab页切换,然后再返回列表页,希望能切换到之前滚动位置

    解决问题思路:

      切换到其他页面前记录位置,返回列表页的时候返回位置。这就需要借助vue-routerbeforeRouteEnterbeforeRouteLeave这两个钩子去实现.

    还有一种更简单粗暴的方法, vue-scroller.min.js源码中添加宽高不为零判断,实现方式见评论,是最近代码优化的时候发现的。

    代码部分:

    beforeRouteEnter(to,from,next){
      if(!sessionStorage.askPositon || from.path == '/'){//当前页面刷新不需要切换位置
        sessionStorage.askPositon = '';
        next();
      }else{
        next(vm => {
            if(vm && vm.$refs.scrollerBottom){//通过vm实例访问this
              setTimeout(function () {
                vm.$refs.scrollerBottom.scrollTo(0, sessionStorage.askPositon, false);
              },0)//同步转异步操作
            }
        })
      }
    },
    beforeRouteLeave(to,from,next){//记录离开时的位置
      sessionStorage.askPositon = this.$refs.scrollerBottom && this.$refs.scrollerBottom.getPosition() && this.$refs.scrollerBottom.getPosition().top;
      next()
    },
    

      需要注意的点:

        1.熟悉vue-router和vue-scroller的api

        2.beforeRouteEnter的时候,是无法通过this去访问vue实例的,需要借助于vm

        3.setTimeout 0 的使用

     等下周发版的时候,我贴上链接,可以体验下效果

  • 相关阅读:
    iOS开发之字符串去掉首尾空格换行
    iOS开发之截取UIScrollView长图方法、截长图
    iOS开发之语音录制
    iOS开发之程序各种状态监听
    iOS开发之监听应用进入前台后台
    iOS开发之波浪动画效果
    mysql 主从一致性检查
    git 备份和恢复
    tomcat server.xml配置文件 解析
    检查MySQL主从数据一致性
  • 原文地址:https://www.cnblogs.com/cjh1111/p/7701194.html
Copyright © 2011-2022 走看看