国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 13:11:53
字體:
來源:轉載
供稿:網友

因為項目需求,最近開始轉到微信公眾號開發,接觸到了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>

參考

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 岱山县| 高安市| 竹北市| 化州市| 左贡县| 高安市| 克什克腾旗| 阿瓦提县| 嘉善县| 定边县| 紫云| 青海省| 浏阳市| 饶平县| 海口市| 佛坪县| 泰兴市| 抚顺县| 宝坻区| 札达县| 新乡市| 呼和浩特市| 襄城县| 武强县| 荔波县| 四会市| 黑水县| 通辽市| 济宁市| 施秉县| 墨玉县| 元朗区| 台江县| 北海市| 扶沟县| 越西县| 车致| 七台河市| 错那县| 宾阳县| 宜宾县|