vue中 进入详情页记住滚动位置(keep-alive)

vue中 进入列表详情计算滚动位置

> 有时业务提出这样一个需求 就是从商品页面进入到列表详情页 要保存当前滚动的位置,这里我就想到了keep-alive
  1. 首先在路由中引入需要的模块
    {
    path: ‘/scrollDemo’,
    name: ‘scrollDemo’,
    meta: {
    keepAlive: true // 需要缓存
    },
    component: resolve => { require([‘../view/scrollDemo.vue’], resolve) }
    }

2.在App.vue中设置缓存组件

    <keep-alive>   // 缓存组件跳转的页面
        <router-view v-if="$route.meta.keepAlive" class="ui-view"  transition-mode="out-in"></router-view>
    </keep-alive>  

  // 非缓存组件跳转页面
  <router-view v-if="!$route.meta.keepAlive" class="ui-view"  transition-mode="out-in"></router-view>

3.在页面注册对应的事件


 1. 在return中定义一个初始值  scroll

 2. 在mouted中 ,mouted中的方法代表dom已经加载完毕
        window.addEventListener('scroll', this.handleScroll);

 3.methods 用于存放页面函数
     handleScroll () {
       this.scroll  = document.documentElement &&  document.documentElement.scrollTop

       console.log(this.scroll)
     }

  4. activated 为keep-alive加载时调用
      activated() {
          if(this.scroll > 0){
            window.scrollTo(0, this.scroll);
            this.scroll = 0;
            window.addEventListener('scroll', this.handleScroll);
          }
    }

5.deactivated 页面退出时关闭事件 防止其他页面出现问题
    deactivated(){
     window.removeEventListener('scroll', this.handleScroll);
    }
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值