日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

30秒实现Vue吸顶效果

發布時間:2024/5/7 vue 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 30秒实现Vue吸顶效果 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

醬醬,好久不見鴨!

前言:吸頂效果圖:

1、滾動前:
image.png
2、滾動中:
image.png
3、滾動超過后:
image.png
直觀效果可參pc端微博左側的信息欄

第一步:html 中:

在你要實現吸頂效果的div上,加上如下這一行代碼:

image.png
下方代碼自取↓

:class="{'is_fixed' : isFixed}"

觸發吸頂效果的位置,如下:

image.png
下方代碼自取↓

<div id="boxFixed"></div>

第二步:data 定義中:

image.png
下方代碼自取↓

data() {return {isFixed: false,offsetTop: 0,}}

第三步:在 mounted 與 destroyed 中

mounted() {window.addEventListener('scroll', this.initHeight);this.$nextTick(() => {//獲取對象相對于版面或由 offsetTop 屬性指定的父坐標的計算頂端位置 this.offsetTop = document.querySelector('#boxFixed').offsetTop;}) }, //回調中移除監聽 destroyed() {window.removeEventListener('scroll', this.handleScroll) },

第四步:在 methods 方法定義中:

/********* start-目錄吸頂********/ initHeight() { // 設置或獲取位于對象最頂端和窗口中可見內容的最頂端之間的距離 (被卷曲的高度)var scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop //如果被卷曲的高度大于吸頂元素到頂端位置 的距離this.isFixed = scrollTop > this.offsetTop ? true : false; }, /********* end-目錄吸頂********/

最后一步:在css中:

.is_fixed{width: 100%;position: fixed;top: 0;z-index: 999; }

大功告成,感謝博文:
https://www.jianshu.com/p/5fc421a2f12a

總結

以上是生活随笔為你收集整理的30秒实现Vue吸顶效果的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。