vue- router 跳转置顶

文章讲述了如何在VueRouter中设置scrollBehavior,确保在history模式下正常工作,而在hash模式(VueRouter4+)时需调整left和top属性。着重于页面滚动位置在路由切换后的恢复问题及其解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

main.js

// const scrollBehavior = (to, from, savedPosition) => {

//   if (savedPosition && to.meta.keepAlive) {

//     return savedPosition;

//   }

//   return { left: 0, top: 0 };

// };

const scrollBehavior = (to, from, savedPosition) => {

  if (savedPosition) {

    return savedPosition;

  } else {

    return { x: 0, y: 0 };

  }

};

const router = new VueRouter({

  mode: "history",

  scrollBehavior,

  routes: routes

});

 

 ps:以上设置在vue-router模式是history下没什么问题。//  x,y

如果在hash模式下,且vue-router的版本为4+,那么返回对象的x,y就要分别修改为left,top。

 参考:

vue切换页面/路由跳转后,页面不会置顶的解决方案_vue2 切换页面设置的scrollbehavior 回到顶部不生效-CSDN博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值