VUE路由跳转记住滚动位置,返回时回到上次滚动位置

本解决方案原理是利用Keep-Alive监听滚动事件watch中监听$route 实现。

使用watch监听$route的方案适用于滚动区域在子组件中的情况。

因为,beforeRouteLeave 路由导航守卫,只能作用在路由组件内,不能被路由组件内的子组件所触发。

vue-router文档截图如下:
在这里插入图片描述

本样例使用element-ui 下的 el-table表格组件,原生或其他UI组件思路同理。


router.js
{
     path: '/dispatchDetail',
     name: 'dispatchDetail',
     component: () => import('@/views/dispatchDetail/index.vue'),
     meta: { title: '日调度情况查询', keepAlive: true  } //需要缓存
},
App.vue
<keep-alive>
   // 缓存组件跳转的页面
  <router-view v-if="$route.meta.keepAlive"></router-view>
</keep-alive>

// 不需要缓存组件的页面
<router-view v-if="!$route.meta.keepAlive"></router-view>
dispatchDetail.vue
 <template>
    <el-table ref="listBox"> // 在el-table标签上 添加ref属性 用于获取滚动区域dom
		...
    </el-table>
 </template>
 <script>
 export default { 
      data() {
        return {
          listBox: '',
          scrollTop: 0,
		}
      }
      
      // 进入缓存组件时监听滚动事件
      activated() {
        this.$refs.listBox.bodyWrapper.addEventListener('scroll', this.scrollToTop)
      },

      // 离开缓存组件时监听滚动事件
      deactivated() {
        this.$refs.listBox.bodyWrapper.removeEventListener('scroll', this.scrollToTop)
      },
      
      watch: {
        $route(to, from) {
          // 如果是来自目标页 并且this.scrollTop > 0 则给滚动区域设置离开时缓存的距顶部高度值
          if (from.name == 'schedulingDetails') {
            if (this.scrollTop > 0) {
              setTimeout(() => {
                this.$refs.listBox.bodyWrapper.scrollTo(0, this.scrollTop)
              }, 0)
            }
          }
          
          // 如果不是去目标页 则将 this.scrollTop 恢复为 0
          if (to.name !== 'schedulingDetails') {
            this.scrollTop = 0
          }
        },
      },
      
      methods: {
          // 定义获取 距顶部滚动高度 方法
          scrollToTop() {
            const scrollTop = this.$refs.listBox.bodyWrapper.scrollTop // 实时获取el-table组件当前滚动位置,距顶部的滚动高度
            this.scrollTop = scrollTop // 赋值给 this.scrollTop 用于下次进入时调用
          },
      }
  }
</script>
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue中,当使用前端路由切换到新的路由,默认情况下滚动条会被重置到页面顶部,不会保持原先的滚动位置。如果你想要在路由切换滚动条置顶,你可以通过自定义路由切换滚动行为来实现。在路由配置中,可以使用scrollBehavior函数来自定义滚动行为。scrollBehavior函数接收三个参数:to(目标路由对象)、from(来源路由对象)和savedPosition(之前的滚动位置)。你可以根据这些参数来自定义滚动行为。如果你想让滚动条路由切换置顶,你可以在scrollBehavior函数中返回{ x: 0, y: 0 }来将滚动条位置重置为页面顶部。这样,在每次路由切换页面都会滚动到顶部。这就是如何在Vue中实现路由跳转滚动条置顶的方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue 切换路由页面滚动条滚动到最上面](https://blog.csdn.net/xingchen678/article/details/128723182)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [vue路由滚动 切换路由之后滚动条在最上面](https://blog.csdn.net/m0_64415782/article/details/131938991)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值