vue-scroller記錄滾動(dòng)位置的示例代碼
問題描述:
列表頁進(jìn)入詳情頁,或者tab頁切換,然后再返回列表頁,希望能切換到之前滾動(dòng)位置
解決問題思路:
切換到其他頁面前記錄位置,返回列表頁的時(shí)候返回位置。這就需要借助vue-router的beforeRouteEnter和beforeRouteLeave這兩個(gè)鉤子去實(shí)現(xiàn).
還有一種更簡(jiǎn)單粗暴的方法, vue-scroller.min.js源碼中添加寬高不為零判斷,實(shí)現(xiàn)方式見評(píng)論,是最近代碼優(yōu)化的時(shí)候發(fā)現(xiàn)的。
代碼部分:
beforeRouteEnter(to,from,next){
if(!sessionStorage.askPositon || from.path == '/'){//當(dāng)前頁面刷新不需要切換位置
sessionStorage.askPositon = '';
next();
}else{
next(vm => {
if(vm && vm.$refs.scrollerBottom){//通過vm實(shí)例訪問this
setTimeout(function () {
vm.$refs.scrollerBottom.scrollTo(0, sessionStorage.askPositon, false);
},0)//同步轉(zhuǎn)異步操作
}
})
}
},
beforeRouteLeave(to,from,next){//記錄離開時(shí)的位置
sessionStorage.askPositon = this.$refs.scrollerBottom && this.$refs.scrollerBottom.getPosition() && this.$refs.scrollerBottom.getPosition().top;
next()
},
需要注意的點(diǎn):
1.熟悉vue-router和vue-scroller的api
2.beforeRouteEnter的時(shí)候,是無法通過this去訪問vue實(shí)例的,需要借助于vm
3.setTimeout 0 的使用
等下周發(fā)版的時(shí)候,我貼上鏈接,可以體驗(yàn)下效果
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 解決Vue頁面固定滾動(dòng)位置的處理辦法
- Vue實(shí)現(xiàn)渲染數(shù)據(jù)后控制滾動(dòng)條位置(推薦)
- vue實(shí)現(xiàn)滾動(dòng)條到頂部或者到指定位置
- vue中實(shí)現(xiàn)點(diǎn)擊按鈕滾動(dòng)到頁面對(duì)應(yīng)位置的方法(使用c3平滑屬性實(shí)現(xiàn))
- vue監(jiān)聽頁面中的某個(gè)div的滾動(dòng)事件并判斷滾動(dòng)的位置
- Vue滾動(dòng)到指定位置的多種方式示例詳解
- Vue滾動(dòng)頁面到指定位置的實(shí)現(xiàn)及避坑
- Vue列表如何實(shí)現(xiàn)滾動(dòng)到指定位置樣式改變效果
- 解決vue無法設(shè)置滾動(dòng)位置的問題
- vue通過滾動(dòng)行為實(shí)現(xiàn)從列表到詳情,返回列表原位置的方法
- Vue頁面返回滾動(dòng)位置恢復(fù)(keep-alive滾動(dòng)記憶)
相關(guān)文章
Vue源碼探究之虛擬節(jié)點(diǎn)的實(shí)現(xiàn)
這篇文章主要介紹了Vue源碼探究之虛擬節(jié)點(diǎn)的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-04-04
如何用vue-cli3腳手架搭建一個(gè)基于ts的基礎(chǔ)腳手架的方法
這篇文章主要介紹了如何用vue-cli3腳手架搭建一個(gè)基于ts的基礎(chǔ)腳手架的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
Vue3?中?watch?與?watchEffect?區(qū)別及用法小結(jié)
這篇文章主要介紹了Vue3?中?watch?與?watchEffect?有什么區(qū)別?watch中需要指明監(jiān)視的屬性,也需要指明監(jiān)視的回調(diào),而watchEffect中不需要指明監(jiān)視的屬性,只需要指明監(jiān)視的回調(diào),回調(diào)函數(shù)中用到哪個(gè)屬性,就監(jiān)視哪個(gè)屬性,本文給大家詳細(xì)介紹,需要的朋友參考下2022-06-06
vue頁面回退或關(guān)閉,發(fā)送請(qǐng)求不中斷問題
這篇文章主要介紹了vue頁面回退或關(guān)閉,發(fā)送請(qǐng)求不中斷問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
vue項(xiàng)目調(diào)試的三種方法總結(jié)
這篇文章主要給大家總結(jié)介紹了關(guān)于vue項(xiàng)目調(diào)試的三種方法,大家可以根據(jù)需要選擇調(diào)試方法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09
在vue里面設(shè)置全局變量或數(shù)據(jù)的方法
下面小編就為大家分享一篇在vue里面設(shè)置全局變量或數(shù)據(jù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-03-03

