Vue3中页面滑到最下面,然后跳转新页面后新页面的位置还是在之前浏览的位置

这个问题可以通过以下两种方式来解决:

  1. 使用路由跳转前获取当前页面的滚动位置并将其作为参数传递给新页面,在新页面加载时将滚动位置设置为传递过来的位置。

例如:

// 在当前页面中获取滚动位置 const scrollPosition = window.scrollY || window.pageYOffset; // 使用路由跳转并将滚动位置作为参数传递给新页面 router.push({ path: '/newpage', query: { scrollPosition } });

// 在新页面中获取传递过来的滚动位置并设置为页面的滚动位置 mounted() { const scrollPosition = this.$route.query.scrollPosition; window.scrollTo(0, scrollPosition); }

  1. 使用浏览器的历史记录管理API(history API)来存储页面的滚动位置,然后在新页面加载时从历史记录中获取并设置滚动位置。

例如:

// 在当前页面中将滚动位置存储到历史记录中 const scrollPosition = window.scrollY || window.pageYOffset; history.replaceState({ scrollPosition }, ''); // 使用路由跳转到新页面 router.push('/newpage');

// 在新页面中获取历史记录中的滚动位置并设置为页面的滚动位置 mounted() { const state = history.state || {}; const scrollPosition = state.scrollPosition || 0; window.scrollTo(0, scrollPosition); }


这个问题可以通过使用Vue Router中的scrollBehavior属性来解决。scrollBehavior属性用于定义页面跳转时的滚动行为。您可以在Vue Router中添加以下代码来解决该问题:

复制代码
const router = new VueRouter({
  mode: 'history',
  scrollBehavior (to, from, savedPosition) {
    if (savedPosition) {
      return savedPosition
    } else {
      return { x: 0, y: 0 }
    }
  },
  routes: [...]
})

在上面的代码中,我们使用了scrollBehavior属性,并在其中检查了savedPosition参数。savedPosition参数保存了当前页面的滚动位置,如果存在此位置,则跳转到新页面时就会保留该位置,否则将滚动到页面的顶部。


这个问题实际上不是Vue3的具体问题,而是浏览器的默认行为。在跳转到新页面时,浏览器会尝试保留上一个页面的滚动位置。但您可以通过JavaScript来解决这个问题。

一种解决方法是在新页面中添加以下代码:

复制代码
window.onload = function() {
  window.scrollTo(0,0);
}

这将在新页面加载时将滚动位置重置为顶部。

另一种方法是使用Vue Router,在路由切换时使用 scrollBehavior 方法来实现滚动位置的控制。例如:

复制代码
const router = new VueRouter({
  routes: [...],
  scrollBehavior (to, from, savedPosition) {
    if (savedPosition) {
      return savedPosition
    } else {
      return { x: 0, y: 0 }
    }
  }
})

这将在路由切换时,如果有保存的滚动位置,则返回此位置,否则返回顶部。


这种情况可能是因为你没有在跳转页面时进行页面滚动的重置,可以通过以下几种方式进行解决:

在路由切换时,使用scrollTo方法将页面滚动回顶部:

javascript 复制代码
const router = createRouter({
  history: createWebHashHistory(),
  routes,
  scrollBehavior(to, from, savedPosition) {
    return { top: 0 }
  }
})

在页面跳转时,手动将页面滚动到顶部:

javascript 复制代码
mounted() {
  window.scrollTo(0, 0)
}

在页面卸载时,使用钩子函数将页面滚动重置为顶部:

javascript 复制代码
beforeUnmount() {
  window.scrollTo(0, 0)
}
相关推荐
神秘的t4 分钟前
Spring Web MVC————入门(3)
前端·后端·spring·mvc
开开心心就好20 分钟前
便捷的电脑自动关机辅助工具
前端·python·pdf·ocr·电脑·音视频·散列表
Python涛哥30 分钟前
前端流行框架Vue3教程:20. 插槽slot(2)
前端·javascript·vue.js
GUIQU.1 小时前
【Node.js】全栈开发实践
前端·node.js·全栈开发
王富贵的记录1 小时前
electron 控制台打印中文乱码问题
前端·javascript·electron
谈不譚网安2 小时前
XXE(外部实体注入)
前端·网络安全
图扑软件3 小时前
GIS 智慧环卫可视化管理系统
大数据·javascript·人工智能·智慧城市·数字孪生·可视化·智慧环卫
老K(郭云开)3 小时前
最新版Chrome浏览器调用ActiveX控件技术——alWebPlugin中间件V2.0.42版发布
前端·chrome·中间件
百锦再4 小时前
Vue环境下数据导出PDF的全面指南
前端·javascript·vue.js·python·django·pdf·pygame
菜鸟una7 小时前
【微信小程序 + 高德地图API 】键入关键字搜索地址,获取经纬度等
前端·vue.js·微信小程序·小程序·typescript