vue通過滾動行為實現(xiàn)從列表到詳情,返回列表原位置的方法
vue項目滾動行為
場景:項目中,從列表進(jìn)入詳情,再從詳情返回列表時,想直接定位到離開時的位置。
列表頁點擊某一個進(jìn)入到詳情頁:
進(jìn)入到詳情頁:
從詳情頁點擊返回到列表頁到離開的位置:
實現(xiàn)方式一:html5 history模式
1在路由設(shè)置router/index.js中,設(shè)置組件的元信息被緩存。(keepAlive:true),并修改mode模式為history。
export defaultnewRouter({
mode: 'history' // 默認(rèn)hash routes: [ // ***************** 列表組件 ******************** // { path: '/', name: list, component: list, meta: { keepAlive: true } }
2該組件路由被匹配顯示的方式:
<keep-alive> <router-view v-if="$route.meta.keepAlive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepAlive"></router-view>
實現(xiàn)方式二:監(jiān)聽scrollTop, js原始寫法(組件同樣需要設(shè)置緩存keep-alive)
1在組件的data中定義一個scrollTop屬性,用來記錄監(jiān)聽的scrollTop。
2在created或者mounted鉤子里添加監(jiān)聽事件。
mounted () { document.addEventListener('scroll',this.handelscroll) },
3在methods方法中定義這個handelscroll方法,并將監(jiān)聽的scrollTop賦值給data中的scrollTop()
handelscroll() { this.scrollTop = document.body.scrollTop|| document.documentElement.scrollTop || window.pageYOffset },
4在deactivated鉤子里記錄當(dāng)前的scrolltop(即從列表頁進(jìn)入詳情頁)
deactivated (){ sessionStorage.setItem('scrollTop',this.scrollTop) },
這里存到了sessionStorage里邊,也可以使用狀態(tài)管理。
5在activated鉤子里,定位保存的scrollTop(即從詳情頁返回列表頁)
activated () { document.body.scrollTop =document.documentElement.scrollTop = window.pageYOffset =sessionStorage.getItem('scrollTop') },
以上這篇vue通過滾動行為實現(xiàn)從列表到詳情,返回列表原位置的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue調(diào)用微信JSDK 掃一掃,相冊等需要注意的事項
這篇文章主要介紹了vue調(diào)用微信JSDK 掃一掃,相冊等需要注意的事項,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2021-01-01vite+element-plus項目基礎(chǔ)搭建的全過程
最近看完Vue3和Vite文檔之后,就寫了個小demo,整體感覺下來還是很絲滑的,下面這篇文章主要給大家介紹了關(guān)于vite+element-plus項目基礎(chǔ)搭建的全過程,需要的朋友可以參考下2022-07-07this.$router.push攜帶參數(shù)跳轉(zhuǎn)頁面的實現(xiàn)代碼
這篇文章主要介紹了this.$router.push攜帶參數(shù)跳轉(zhuǎn)頁面,this.$router.push進(jìn)行頁面跳轉(zhuǎn)時,攜帶參數(shù)有params和query兩種方式,本文結(jié)合實例代碼給大家詳細(xì)講解,需要的朋友可以參考下2023-04-04defineProps宏函數(shù)不需要從vue中import導(dǎo)入的原因解析
這篇文章主要介紹了defineProps宏函數(shù)不需要從vue中import導(dǎo)入的原因解析,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07