国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Vue開發實現吸頂效果的示例代碼

來源:懂視網 責編:小采 時間:2020-11-27 22:09:37
文檔

Vue開發實現吸頂效果的示例代碼

Vue開發實現吸頂效果的示例代碼:因為項目需求,最近開始轉到微信公眾號開發,接觸到了Vue框架,這個效果的實現雖說是基于Vue框架下實現的,但是同樣也可以借鑒到其他地方,原理都是一樣的。 進入正題,先看下效果圖: 其實js做這個效果還是挺簡單的,因為在css中我們可以設置一個元素的
推薦度:
導讀Vue開發實現吸頂效果的示例代碼:因為項目需求,最近開始轉到微信公眾號開發,接觸到了Vue框架,這個效果的實現雖說是基于Vue框架下實現的,但是同樣也可以借鑒到其他地方,原理都是一樣的。 進入正題,先看下效果圖: 其實js做這個效果還是挺簡單的,因為在css中我們可以設置一個元素的

因為項目需求,最近開始轉到微信公眾號開發,接觸到了Vue框架,這個效果的實現雖說是基于Vue框架下實現的,但是同樣也可以借鑒到其他地方,原理都是一樣的。

進入正題,先看下效果圖:

 

其實js做這個效果還是挺簡單的,因為在css中我們可以設置一個元素的 position: fixed;

,這樣它就可以固定在那里,這樣不管頁面怎么滾動,它的位置都不受影響,所以我們的思路就是在合適的時機把要吸頂的頭部元素的position屬性設置為fixed就可以了。但是這個合適的時機是什么時候呢,這就需要我們計算了,我們需要監聽頁面的滾動狀態,當頁面滾動到要吸頂元素所處的位置的時候就是我們設置它固定的時候,所以就需要我們:

1.監聽頁面的滾動狀態:

在mounted回調中加入以下代碼:

mounted() {
 // handleScroll為頁面滾動的監聽回調
 window.addEventListener('scroll', this.handleScroll);
 },

同時在destroyed回調中移除監聽:

destroyed(){
 window.removeEventListener('scroll', this.handleScroll);
},

2.計算吸頂元素到頁面頂部的距離:

計算出來這個距離之后就可以確定固定吸頂元素的時機了,如果你的吸頂元素上面的元素的高度是固定的話,那就簡單了,直接在handleScroll方法中進行判斷就可以了,可以直接跳到第三步了,如果是動態的,那就需要我們在接口請求完數據,dom元素渲染完之后進行動態計算了,Vue中有一個很好用的方法,可以很方便的監聽dom渲染完成:

// 監聽dom渲染完成
this.$nextTick(function(){
 // 這里fixedHeaderRoot是吸頂元素的ID
 let header = document.getElementById("fixedHeaderRoot");
 // 這里要得到top的距離和元素自身的高度
 this.offsetTop = header.offsetTop;
 this.offsetHeight = header.offsetHeight;
 console.log("offsetTop:" + this.offsetTop + "," + this.offsetHeight);
});

3.判斷頁面滾動距離:

handleScroll(){
 // 得到頁面滾動的距離
 let scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop;
 // 判斷頁面滾動的距離是否大于吸頂元素的位置
 this.headerFixed = scrollTop > (this.offsetTop - this.offsetHeight * 2);
},

ps:這里理論上其實應該是scrollTop > (this.offsetTop - this.offsetHeight),但是不知道為啥我這里做出來后滾動到吸頂元素位置的時候scrollTop還是比this.offsetTop - this.offsetHeight的值小,所以這里*2,這樣得出來的值才剛剛好,如果有知道的朋友可以幫忙解惑一下。

上面我們得到了一個headerFixed的boolean屬性值,接下來我們只需要根據它的值來設置吸頂元素的 position: fixed; 屬性就可以了。 我們可以寫一個css樣式:

.isFixed{
 position: fixed;
 top: px2rem(110);
 left: px2rem(20);
 right: px2rem(20);
}

然后Vue可以在dom元素里這樣動態設置class,非常方便:

<div id="fixedHeaderRoot">
 <div id="knowPointHeader" class="knowPointHeader" :class="headerFixed?'isFixed':''">
 <div><span>知識模塊</span></div>
 <div><span>知識點</span></div>
 <div><span>能力要求</span></div>
 </div>
</div>

其實到這里這個效果已經實現完成了,不過我在測試過程中發現,因為ios手機頁面滾動到底部的時候,還可以上拉,有一個橡皮筋效果,這個效果會導致一個我們頁面的一個Bug,因為它的這種橡皮筋效果也會觸發頁面滾動的監聽,當數據很多的時候其實看不出來,只有當數據剛好占滿屏幕的時候,這個時候你再繼續往上滑動屏幕,就會觸發頁面的滾動監聽,這個時候handleScroll方法中計算出來的值scrollTop是大于吸頂元素top的距離,所以吸頂元素會被設置為固定屬性,大家知道一個元素一旦被設置為 position: fixed; ,那么它就會相對于瀏覽器窗口進行定位,這樣我們下面的內容就會往上頂,這樣的話scrollTop的值又小于了吸頂元素top的距離,這樣headerFixed屬性又為false, position: fixed; 屬性又沒有了,這樣它就又相對與它原本的父元素進行定位,這樣就成了一個循環,你會發現頁面會上下跳到,這樣是肯定不行的,所以我下面又針對這個問題進行了一個優化,當然這個方案感覺不是特別完美,不過確實可以解決這個問題。

通過上面的分析我們可以得知造成這個問題的原因是因為我們把設置了元素的 position: fixed; 屬性,使得下面的內容往上頂,所以要想解決這個問題,那我們就不固定這個元素,但是這樣的話就達不到吸頂的效果了,所以我們需要再加一個和吸頂元素一模一樣的元素,它一直就是固定狀態:

<div id="fixedHeaderRootReal">
 <div class="knowPointHeader isFixed" v-show="headerFixed">
 <div><span>知識模塊</span></div>
 <div><span>知識點</span></div>
 <div><span>能力要求</span></div>
 </div>
</div>

這個元素默認是隱藏的,只有當頁面滾動的距離達到了它的位置的時候我們才讓它顯示,由于它是固定狀態,所以它的隱藏顯示并不會對頁面產生影響,這樣下面的內容就不會往上頂了,就可以解決ios手機上拉頁面橡皮筋效果的Bug了,當然這種方式有些取巧,但是暫時沒有更好的解決方案了,如果大家有更好的解決方案,歡迎在下面評論。最后給大家看一下我的頁面布局:

<div v-show="kpointListShow" class="knowPointList">
 <div id="fixedHeaderRoot">
 <div id="knowPointHeader" class="knowPointHeader">
 <div><span>知識模塊</span></div>
 <div><span>知識點</span></div>
 <div><span>能力要求</span></div>
 </div>
 </div>
 <div id="fixedHeaderRootReal">
 <div class="knowPointHeader isFixed" v-show="headerFixed">
 <div><span>知識模塊</span></div>
 <div><span>知識點</span></div>
 <div><span>能力要求</span></div>
 </div>
 </div>
 <div class="knowPointItem" v-for="(kpointItem,index) in rows.kpointList" :key="index">
 <div><span>{{kpointItem.knowModule}}</span></div>
 <div><span>{{kpointItem.knowPoint}}</span></div>
 <div><span>{{kpointItem.abilityRequire}}</span></div>
 </div>
</div>

參考

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Vue開發實現吸頂效果的示例代碼

Vue開發實現吸頂效果的示例代碼:因為項目需求,最近開始轉到微信公眾號開發,接觸到了Vue框架,這個效果的實現雖說是基于Vue框架下實現的,但是同樣也可以借鑒到其他地方,原理都是一樣的。 進入正題,先看下效果圖: 其實js做這個效果還是挺簡單的,因為在css中我們可以設置一個元素的
推薦度:
標簽: VUE 開發 實現
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 欧美视频一区二区在线观看 | 欧美一区三区 | 亚洲97 | 国产福利视精品永久免费 | 亚洲欧美一区二区三区九九九 | 国产日韩欧美第一页 | 国产精品永久免费自在线观看 | 亚洲伊人网站 | 欧美我不卡 | 亚洲 另类 在线 欧美 制服 | 久久一区二区三区精品 | 一级成人毛片免费观看 | 国产1区2区 | 国产免费观看网站 | 日韩在线观看视频网站 | 国产精选视频在线观看 | 日本高清一二三区 | 日本一区二区三区在线播放 | 久久一区二区精品综合 | 久久久久久久国产高清 | 91精品国产高清91久久久久久 | 自拍亚洲 | 国产一区二区三区日韩欧美 | 午夜又黄又爽 | 国产99视频精品草莓免视看 | 国产成人精品亚洲一区 | 国产网站在线免费观看 | 制服丝袜中文在线 | 国产免费观看视频 | 国偷自产一区二区免费视频 | 欧美一区二区三区四区在线观看 | 欧美 日韩 成人 | 国产成人a一区二区 | 全部费免一级毛片不收费 | 曰韩在线| 青青热久久国产久精品 | 欧美成人一级视频 | 日韩 亚洲 制服 欧美 综合 | 免费国产线观看免费观看 | 中文字幕日本一本二本三区 | 丝袜制服中文字幕 |