vue-router中scrollBehavior的巧妙用法
問(wèn)題:使用keep-alive標(biāo)簽后部分安卓機(jī)返回緩存頁(yè)位置不精確問(wèn)題
解決方案:
<div id="app"> <keep-alive> <router-view v-if="$route.meta.keepAlive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepAlive"></router-view> </div> const router = new Router({ scrollBehavior(to, from, savedPosition) { if (savedPosition && to.meta.keepAlive) { return savedPosition; } return { x: 0, y:0 }; }, });
2. 頁(yè)面返回出現(xiàn)空白屏問(wèn)題
問(wèn)題
【前提】:iOS設(shè)備
【步驟】: 頁(yè)面A是個(gè)列表很長(zhǎng)-->滑到頁(yè)腳的時(shí)候點(diǎn)擊跳轉(zhuǎn)之后到頁(yè)面B--->再返回A頁(yè)面
--->屏幕會(huì)出現(xiàn)空白遮罩層--->手指輕觸屏幕滑動(dòng)--->遮罩層消失
解決方案一
在接口請(qǐng)求成功后的回調(diào)操作完成后進(jìn)行該操作,例如
// fetchCourseList是一個(gè)封裝好的Promise請(qǐng)求 fetchCourseList().then(({ data: courses }) => { this.courses = courses; }).then(() => { setTimeout(() => { window.scrollTo(0, 1); window.scrollTo(0, 0); }); });
該方案的弊端: 每個(gè)頁(yè)面都需要做這樣的處理,不推薦使用。
解決方案二(推薦)
使用scrollBehavior中的異步滾動(dòng)操作
const router = new Router({ scrollBehavior(to, from, savedPosition) { // keep-alive 返回緩存頁(yè)面后記錄瀏覽位置 if (savedPosition && to.meta.keepAlive) { return savedPosition; } // 異步滾動(dòng)操作 return new Promise((resolve) => { setTimeout(() => { resolve({ x: 0, y: 1 }); }, 0); }); }, });
該方案直接在路由進(jìn)行處理,兼容每個(gè)頁(yè)面并且頁(yè)面加載完后并也不會(huì)產(chǎn)生1px的滾動(dòng)位置。
總結(jié)
以上所述是小編給大家介紹的vue-router中scrollBehavior的巧妙用法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- vue實(shí)現(xiàn)同一個(gè)頁(yè)面可以有多個(gè)router-view的方法
- 解決vue.js this.$router.push無(wú)效的問(wèn)題
- 基于vue-router 多級(jí)路由redirect 重定向的問(wèn)題
- 全面解析vue router 基本使用(動(dòng)態(tài)路由,嵌套路由)
- 對(duì)vue2.0中.vue文件頁(yè)面跳轉(zhuǎn)之.$router.push的用法詳解
- 淺析vue-router jquery和params傳參(接收參數(shù))$router $route的區(qū)別
- Vue-router 中hash模式和history模式的區(qū)別
- vue-router中的hash和history兩種模式的區(qū)別
- vue router總結(jié) $router和$route及router與 router與route區(qū)別
相關(guān)文章
Vite配置優(yōu)雅的code?spliiting代碼分割詳解
這篇文章主要為大家介紹了Vite配置優(yōu)雅的code?spliiting代碼分割詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08使用proxytable 配置解決 vue-cli 的跨域請(qǐng)求問(wèn)題【推薦】
這篇文章主要介紹了利用 proxytable 配置解決 vue-cli 的跨域請(qǐng)求問(wèn)題,本文的目錄結(jié)構(gòu)基于 webpack 模板結(jié)構(gòu),需要的朋友可以參考下2018-05-05vue利用Moment插件格式化時(shí)間的實(shí)例代碼
Moment.js 是一個(gè) JavaScript 日期處理類庫(kù),用于解析、檢驗(yàn)、操作、以及顯示日期。這篇文章主要給大家介紹了關(guān)于vue利用Moment插件格式化時(shí)間的相關(guān)資料,需要的朋友可以參考下2021-05-05Vue中對(duì)比scoped css和css module的區(qū)別
這篇文章主要介紹了Vue中scoped css和css module的區(qū)別對(duì)比,scoped css可以直接在能跑起來(lái)的vue項(xiàng)目中使用而css module需要增加css-loader配置才能生效。具體內(nèi)容詳情大家參考下本文2018-05-05Vue路由與a標(biāo)簽鏈接錨點(diǎn)發(fā)生沖突問(wèn)題及解決
這篇文章主要介紹了Vue路由與a標(biāo)簽鏈接錨點(diǎn)發(fā)生沖突問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03在Vue3中為路由Query參數(shù)標(biāo)注類型的方法
這篇文章主要介紹了在Vue3中如何為路由Query參數(shù)標(biāo)注類型,我們就針對(duì)這個(gè)話題如何為路由Query參數(shù)標(biāo)注類型為例,看看Composable和IOC容器的代碼風(fēng)格究竟有什么不同,需要的朋友可以參考下2024-08-08