vue-router中scrollBehavior的巧妙用法
問題:使用keep-alive標簽后部分安卓機返回緩存頁位置不精確問題
解決方案:
<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. 頁面返回出現(xiàn)空白屏問題
問題
【前提】:iOS設(shè)備
【步驟】: 頁面A是個列表很長-->滑到頁腳的時候點擊跳轉(zhuǎn)之后到頁面B--->再返回A頁面
--->屏幕會出現(xiàn)空白遮罩層--->手指輕觸屏幕滑動--->遮罩層消失
解決方案一
在接口請求成功后的回調(diào)操作完成后進行該操作,例如
// fetchCourseList是一個封裝好的Promise請求
fetchCourseList().then(({ data: courses }) => {
this.courses = courses;
}).then(() => {
setTimeout(() => {
window.scrollTo(0, 1);
window.scrollTo(0, 0);
});
});
該方案的弊端: 每個頁面都需要做這樣的處理,不推薦使用。
解決方案二(推薦)
使用scrollBehavior中的異步滾動操作
const router = new Router({
scrollBehavior(to, from, savedPosition) {
// keep-alive 返回緩存頁面后記錄瀏覽位置
if (savedPosition && to.meta.keepAlive) {
return savedPosition;
}
// 異步滾動操作
return new Promise((resolve) => {
setTimeout(() => {
resolve({ x: 0, y: 1 });
}, 0);
});
},
});
該方案直接在路由進行處理,兼容每個頁面并且頁面加載完后并也不會產(chǎn)生1px的滾動位置。
總結(jié)
以上所述是小編給大家介紹的vue-router中scrollBehavior的巧妙用法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- vue實現(xiàn)同一個頁面可以有多個router-view的方法
- 解決vue.js this.$router.push無效的問題
- 基于vue-router 多級路由redirect 重定向的問題
- 全面解析vue router 基本使用(動態(tài)路由,嵌套路由)
- 對vue2.0中.vue文件頁面跳轉(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)文章
Vue實現(xiàn)點擊導(dǎo)航欄當前標簽后變色功能
這篇文章主要為大家詳細介紹了Vue實現(xiàn)點擊導(dǎo)航欄當前標簽后變色功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-08-08
Vue.js實現(xiàn)實例搜索應(yīng)用功能詳細代碼
本文給大家分享Vue.js實現(xiàn)實例搜索應(yīng)用功能詳細代碼,非常不錯,感興趣的朋友參考下吧2017-08-08
vue動態(tài)綁定多個class以及帶上三元運算或其他條件
這篇文章主要介紹了vue動態(tài)綁定多個class以及帶上三元運算或其他條件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
Vue開發(fā)中出現(xiàn)Loading?Chunk?Failed的問題解決
本文主要介紹了Vue開發(fā)中出現(xiàn)Loading?Chunk?Failed的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-03-03
Vue整合Node.js直連Mysql數(shù)據(jù)庫進行CURD操作過程詳解
這篇文章主要給大家分享Vue整合Node.js,直連Mysql數(shù)據(jù)庫進行CURD操作的詳細過程,文中有詳細的代碼講解,具有一定的參考價值,需要的朋友可以參考下2023-07-07
如何使用VuePress搭建一個類型element ui文檔
這篇文章主要介紹了如何使用VuePress搭建一個類型element ui文檔,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02
node+vue前后端分離實現(xiàn)登錄時使用圖片驗證碼功能
這篇文章主要介紹了node+vue前后端分離實現(xiàn)登錄時使用圖片驗證碼,記錄前端使用驗證碼登錄的過程,后端用的是node.js,關(guān)鍵模塊是svg-captcha,結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2022-11-11

