久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

vue實現導航標題欄隨頁面滾動漸隱漸顯效果

瀏覽:73日期:2023-01-31 16:24:16

項目開發中導航欄隨頁面滾動漸隱漸顯這一功能還是較為常用的,下面作一個用vue實現此功能的代碼分享。

1. 為導航欄元素style屬性用v-bind綁定data數據'opacityStyle'。

<div :style='opacityStyle'> 景點詳情 //內容我就簡約了,實際開發以需求為準</div>

2. data中定義opacityStyle,數據內容是opacity透明度屬性,設置為0。

data() { return { opacityStyle:{ opacity:0 } }}

3. 監聽scroll事件并執行相應方法,一般我習慣在activated生命周期時開始監聽(activated是keepAlive屬性下產生的一個生命周期,在進入頁面時)。

activated(){ window.addEventListener(’scroll’,this.handleScroll)}

4. 設計handleScroll()方法。通過獲取scroll滾動偏移值,指定數值對opacity屬性進行計算,讓透明度聯動變化。

methods:{ handleScroll(){ const top = document.documentElement.scrollTop //獲取scroll偏移值 if(top > 45 && top <= 150){ //實際按需求取范圍 const opacity = top / 150 //對opacity作計算,透明度從起始到1隨偏移值而改變 this.opacityStyle = {opacity} //實時返回給opacityStyle } }}

5. 對scroll監聽進行解綁。剛剛在activated()中執行監聽,同樣的我們在deactivated()中移除監聽。這一步很重要,很多人都會忽略,如果不解除將可能影響到其他頁面的scroll行為,導致項目產生bug。

deactivated(){ window.removeEventListener(’scroll’,this.handleScroll)}

以上是vue實現頁面滾動顯隱導航欄功能的代碼和邏輯,有疑惑例如keepAlive用法等不明白的地方可查看文檔另外學習~

總結

到此這篇關于vue實現導航標題欄隨頁面滾動漸隱漸顯效果的文章就介紹到這了,更多相關vue 導航標題欄滾動漸隱漸顯內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
主站蜘蛛池模板: 庐江县| 措勤县| 无极县| 广汉市| 宁蒗| 峡江县| 雅安市| 临猗县| 鄢陵县| 永昌县| 榕江县| 民县| 沂南县| 乐陵市| 沿河| 青海省| 新源县| 宕昌县| 奉化市| 赤水市| 黄骅市| 新平| 宿松县| 崇义县| 安阳县| 德阳市| 东港市| 泰安市| 淮安市| 万山特区| 宁武县| 社旗县| 达尔| 东平县| 石河子市| 伊宁县| 军事| 浦县| 遂溪县| 恩施市| 仪陇县|