vue的路由滚动 切换路由之后滚动条在最上面

vue的路由滚动:

当我们切换路由页面时,他默认还是上一个页面的滚动条位置,那么如何切换路由时滚动条在最上面呢?

解决方案:

在Vue中,你可以通过路由滚动行为来控制页面切换时滚动条的位置。默认情况下,Vue Router会将滚动条的位置重置为顶部。

如果你想自定义路由切换时的滚动行为,可以在路由配置中使用scrollBehavior函数。这个函数接收三个参数:to(目标路由对象),from(来源路由对象)和savedPosition(之前的滚动位置)。你可以根据这些参数来自定义滚动行为。

下面是一个示例:

const router = new VueRouter({
  routes: [
    // 路由配置
  ],
  scrollBehavior(to, from, savedPosition) {
    if (savedPosition) {
      // 如果之前有保存滚动位置,则恢复到之前保存的位置
      return savedPosition;
    } else {
      // 否则,默认滚动到页面顶部
      return { x: 0, y: 0 };
    }
  }
})

可查看官方文档

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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 ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值