vue中进入详情页记住滚动位置的方法(keep

今天小编就为大家分享一篇vue中进入详情页记住滚动位置的方法(keep-alive),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

> 有时业务提出这样一个需求 就是从商品页面进入到列表详情页 要保存当前滚动的位置,这里我就想到了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" transition-mode="out-in"></router-view> </keep-alive> // 非缓存组件跳转页面 <router-view v-if="!$route.meta.keepAlive" 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); }

以上这篇vue中进入详情页记住滚动位置的方法(keep-alive)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/c2fb6f79153e9120a640a1bd317083b8.html