91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue如何通過滾動行為實現從列表到詳情

發布時間:2021-07-23 10:46:47 來源:億速云 閱讀:134 作者:小新 欄目:web開發

這篇文章主要介紹了vue如何通過滾動行為實現從列表到詳情,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

vue項目滾動行為

場景:項目中,從列表進入詳情,再從詳情返回列表時,想直接定位到離開時的位置。

列表頁點擊某一個進入到詳情頁:

vue如何通過滾動行為實現從列表到詳情

進入到詳情頁:

vue如何通過滾動行為實現從列表到詳情

從詳情頁點擊返回到列表頁到離開的位置:

vue如何通過滾動行為實現從列表到詳情

實現方式一:html5 history模式

1在路由設置router/index.js中,設置組件的元信息被緩存。(keepAlive:true),并修改mode模式為history。

export defaultnewRouter({
 mode: 'history' // 默認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>

實現方式二:監聽scrollTop, js原始寫法(組件同樣需要設置緩存keep-alive)

1在組件的data中定義一個scrollTop屬性,用來記錄監聽的scrollTop。

2在created或者mounted鉤子里添加監聽事件。

mounted () {
 document.addEventListener('scroll',this.handelscroll)
},

3在methods方法中定義這個handelscroll方法,并將監聽的scrollTop賦值給data中的scrollTop()

handelscroll() {
 this.scrollTop = document.body.scrollTop|| document.documentElement.scrollTop || window.pageYOffset
},

4在deactivated鉤子里記錄當前的scrolltop(即從列表頁進入詳情頁)

deactivated (){
 sessionStorage.setItem('scrollTop',this.scrollTop)
},

這里存到了sessionStorage里邊,也可以使用狀態管理。

5在activated鉤子里,定位保存的scrollTop(即從詳情頁返回列表頁)

activated () {
 document.body.scrollTop =document.documentElement.scrollTop = window.pageYOffset =sessionStorage.getItem('scrollTop')
},

感謝你能夠認真閱讀完這篇文章,希望小編分享的“vue如何通過滾動行為實現從列表到詳情”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

清镇市| 新安县| 邻水| 阆中市| 远安县| 静安区| 庆阳市| 丽水市| 铜梁县| 天镇县| 连州市| 阿城市| 浮梁县| 陆川县| 西昌市| 沙雅县| 玉树县| 陕西省| 甘泉县| 曲水县| 雅安市| 上蔡县| 霍山县| 兴城市| 清徐县| 五指山市| 子长县| 彭山县| 平阳县| 临海市| 盐池县| 夹江县| 汾阳市| 灌阳县| 盐山县| 封丘县| 行唐县| 寿宁县| 廉江市| 舟曲县| 东乡|