最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

关于vue-scroller记录滚动位置的代码介绍

来源:动视网 责编:小采 时间:2020-11-27 19:34:35
文档

关于vue-scroller记录滚动位置的代码介绍

关于vue-scroller记录滚动位置的代码介绍:本篇文章主要介绍了vue-scroller记录滚动位置的示例代码,内容挺不错的,现在分享给大家,也给大家做个参考。问题描述:列表页进入详情页,或者tab页切换,然后再返回列表页,希望能切换到之前滚动位置解决问题思路:切换到其他页面前记录位置,返回列表页的时
推荐度:
导读关于vue-scroller记录滚动位置的代码介绍:本篇文章主要介绍了vue-scroller记录滚动位置的示例代码,内容挺不错的,现在分享给大家,也给大家做个参考。问题描述:列表页进入详情页,或者tab页切换,然后再返回列表页,希望能切换到之前滚动位置解决问题思路:切换到其他页面前记录位置,返回列表页的时


本篇文章主要介绍了vue-scroller记录滚动位置的示例代码,内容挺不错的,现在分享给大家,也给大家做个参考。

问题描述:

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

解决问题思路:

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

还有一种更简单粗暴的方法, 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 的使用

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

文档

关于vue-scroller记录滚动位置的代码介绍

关于vue-scroller记录滚动位置的代码介绍:本篇文章主要介绍了vue-scroller记录滚动位置的示例代码,内容挺不错的,现在分享给大家,也给大家做个参考。问题描述:列表页进入详情页,或者tab页切换,然后再返回列表页,希望能切换到之前滚动位置解决问题思路:切换到其他页面前记录位置,返回列表页的时
推荐度:
标签: VUE 代码 记录位置
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top