vue中使用vue-router切换页面时滚动条自动滚动到顶部的方法
有时候我们需要页面滚动条滚动到某一固定的位置,一般使用window scrollto()
方法。
语法就是:scrollto(xpos,ypos)
xpos:必需。要在窗口文档显示区左上角显示的文档的 x 坐标。
ypos:必需。要在窗口文档显示区左上角显示的文档的 y 坐标。
例如滚动内容的坐标位置100,500:
window.scrollto(100,500);
好了,这个scrolltop这儿只是简单介绍一下,下面我们介绍下veu-router中的滚动行为。
使用前端路由,当切换到新路由时,想要页面滚到顶部,或者是保持原先的滚动位置,就像重新加载页面那样。 vue-router 能做到,而且更好,它让你可以自定义路由切换时页面如何滚动。
注意: 这个功能只在 html5 history 模式下可用。
当创建一个 router 实例,你可以提供一个 scrollbehavior 方法:
const router = new vuerouter({ routes: [...], scrollbehavior (to, from, savedposition) { // return 期望滚动到哪个的位置 } })
scrollbehavior 方法接收 to 和 from 路由对象。第三个参数 savedposition 当且仅当 popstate 导航 (通过浏览器的 前进/后退 按钮触发) 时才可用。
这个方法返回滚动位置的对象信息,长这样:
{ x: number, y: number } { selector: string, offset? : { x: number, y: number }} (offset 只在 2.6.0+ 支持)
如果返回一个 falsy (译者注:falsy 不是 false,参考这里)的值,或者是一个空对象,那么不会发生滚动。
举例:
scrollbehavior (to, from, savedposition) { return { x: 0, y: 0 } }
对于所有路由导航,简单地让页面滚动到顶部。
返回 savedposition,在按下 后退/前进 按钮时,就会像浏览器的原生表现那样:
scrollbehavior (to, from, savedposition) { if (savedposition) { return savedposition } else { return { x: 0, y: 0 } } }
如果你要模拟『滚动到锚点』的行为:
scrollbehavior (to, from, savedposition) { if (to.hash) { return { selector: to.hash } } }
我们还可以利用路由元信息更细颗粒度地控制滚动。
routes: [ { path: '/', component: home, meta: { scrolltotop: true }}, { path: '/foo', component: foo }, { path: '/bar', component: bar, meta: { scrolltotop: true }} ]
完整的例子:
import vue from 'vue' import vuerouter from 'vue-router' vue.use(vuerouter) const home = { template: '<div>home</div>' } const foo = { template: '<div>foo</div>' } const bar = { template: ` <div> bar <div style="height:500px"></div> <p id="anchor">anchor</p> </div> ` } // scrollbehavior: // - only available in html5 history mode // - defaults to no scroll behavior // - return false to prevent scroll const scrollbehavior = (to, from, savedposition) => { if (savedposition) { // savedposition is only available for popstate navigations. return savedposition } else { const position = {} // new navigation. // scroll to anchor by returning the selector if (to.hash) { position.selector = to.hash } // check if any matched route config has meta that requires scrolling to top if (to.matched.some(m => m.meta.scrolltotop)) { // cords will be used if no selector is provided, // or if the selector didn't match any element. position.x = 0 position.y = 0 } // if the returned position is falsy or an empty object, // will retain current scroll position. return position } } const router = new vuerouter({ mode: 'history', base: __dirname, scrollbehavior, routes: [ { path: '/', component: home, meta: { scrolltotop: true }}, { path: '/foo', component: foo }, { path: '/bar', component: bar, meta: { scrolltotop: true }} ] }) new vue({ router, template: ` <div id="app"> <h1>scroll behavior</h1> <ul> <li><router-link to="/">/</router-link></li> <li><router-link to="/foo">/foo</router-link></li> <li><router-link to="/bar">/bar</router-link></li> <li><router-link to="/bar#anchor">/bar#anchor</router-link></li> </ul> <router-view class="view"></router-view> </div> ` }).$mount('#app')
在网上查了一下,网友说还可以试试在main.js入口文件配合vue-router写这个
router.aftereach((to,from,next) => { window.scrollto(0,0); });
总结
以上所述是小编给大家介绍的vue中使用vue-router切换页面时滚动条自动滚动到顶部的方法,希望对大家有所帮助
下一篇: 一道关于单词归类的算法题简单求解