vue中进入详情页记住滚动位置的方法(keep-alive)
>有时业务提出这样一个需求就是从商品页面进入到列表详情页要保存当前滚动的位置,这里我就想到了keep-alive
1.首先在路由中引入需要的模块
{ path:‘/scrollDemo', name:‘scrollDemo', meta:{ keepAlive:true//需要缓存 }, component:resolve=>{require([‘../view/scrollDemo.vue'],resolve)} }
2.在App.vue中设置缓存组件
//缓存组件跳转的页面 //非缓存组件跳转页面
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)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。