400-650-7353
您所在的位置:首頁 > IT干貨資料 > web前端 > 【Web前端基礎知識】如何使用js實現固釘效果

【Web前端基礎知識】如何使用js實現固釘效果

  • 發布: Web前端培訓
  • 來源:Web前端干貨資料
  • 2021-03-22 16:29:11
  • 閱讀()
  • 分享
  • 手機端入口

當內容區域比較長,需要滾動頁面時,部分內容需要在滾動范圍內的頂部始終展現,這種效果就稱之為固釘。那我們該如何使用js來實現這種結果呢。

在實現該效果之前,我們需要掌握body位置屬性中offset系列和scroll系列。

其關系如下圖所示:

offset系列中常用的屬性為:

1. 獲取元素的占位寬高

① 元素.offsetWidth:獲取元素的占位寬—width+padding+border

② 元素.offsetHeight:獲取元素的占位高—height+padding+border

2. 獲取元素在頁面中的位置

① 元素.offsetTop:當前元素的頂部,到定位父元素的距離,沒有定位父元素,到 body 的距離;

② 元素.offsetLeft:當前元素的左邊,到定位父元素的距離,沒有定位父元素,到 body 的距離;

scroll系列中常用的為:

1. 元素的滾動(當該元素內部出現了滾動條)

① 元素.scrollTop:元素被卷去的高;

② 元素.scrollLeft:元素被卷去的寬;

③ 元素.scrollWidth:獲取元素實際內容寬;

④ 元素.scrollHeight:獲取元素實際內容高;

2. 屏幕的滾動距離:

document.documentElement.scrollTop:獲取頁面被卷去的高。

為了兼容ie一般為則需要用 document.body 代替 document.documentElement。

那之后我們來分析我們要實現的效果,例如在該圖示中黑色矩形代表窗口,紅色矩形代表整個html頁面,在我們滾動頁面時當黃色塊走到窗口頂部時讓其停留在窗口頂部。

接下來頁面滾動時我們需要知道當前頁面的滾動距離即document.documentElement

.scrollTop,和黃色塊距離頁面頂部的距離即offsetTop,在滾動的過程中比較這兩個值的大小,當頁面被卷去的高度 >= 黃色塊距離頁面頂部的距離時,黃色塊應該定在窗口頂端,這時應該給黃色塊添加一個固定定位。當條件不滿足時,再將其固定定位取消掉。

代碼為:

  1. <style> 
  2. div{ 
  3.         width: 100%; 
  4.         height: 150px; 
  5.         background: tomato; 
  6.         margin-bottom: 10px; 
  7.     } 
  8.     #con{ 
  9.         background: yellow; 
  10.     } 
  11.     .active{ 
  12.         position: fixed; 
  13.         top:0; 
  14.         left: 0; 
  15.     } 
  16. </style> 
  17. <body> 
  18.     <div></div> 
  19.     <div></div> 
  20.     <div></div> 
  21.     <div></div> 
  22.     <div id="con"></div> 
  23.     <div></div> 
  24.     <div></div> 
  25.     <div></div> 
  26.     <div></div> 
  27.     <div></div> 
  28.     <div></div> 
  29. </body> 
  30. <script> 
  31.     var oCon = document.getElementById('con'); 
  32.     // 需要先在外面存儲一下這個值,因為加了定位之后會變為獲取到定位父元素的距離,為0 
  33.     var offsetT = oCon.offsetTop; 
  34. // 當頁面被卷去的高度 >= 紅盒子在頁面中的位置時,紅盒子就定在頂部 
  35. // 添加滾動事件 
  36.     window.onscroll = function(){ 
  37.         var scrollH = document.documentElement.scrollTop || document.body.scrollTop; 
  38.         if(scrollH >= offsetT){ 
  39.              oCon.className = 'active'
  40.         }else{ 
  41.              oCon.className = ''
  42.          } 
  43.     } 
  44. </script> 

需要注意的是:在頁面滾動之前我們要先獲取黃色塊距離頁面頂部的距離,因為offsetTop的值在元素沒有定位的情況下,獲取的才是其在頁面中的位置。當加了固定定位之后該值會為0,之后條件判斷永遠為真,則取消固定定位時無效。

文章“【Web前端基礎知識】如何使用js實現固釘效果”已幫助

>>本文地址:http://www.028benet.com/zhuanye/2021/68022.html

THE END  

聲明:本站稿件版權均屬中公教育優就業所有,未經許可不得擅自轉載。

1 您的年齡

2 您的學歷

3 您更想做哪個方向的工作?

獲取測試結果
  • 大前端大前端
  • 大數據大數據
  • 互聯網營銷互聯網營銷
  • JavaJava
  • Linux云計算Linux
  • Python+人工智能Python
  • 嵌入式物聯網嵌入式
  • 全域電商運營全域電商運營
  • 軟件測試軟件測試
  • 室內設計室內設計
  • 平面設計平面設計
  • 電商設計電商設計
  • 網頁設計網頁設計
  • 全鏈路UI/UE設計UI設計
  • VR/AR游戲開發VR/AR
  • 網絡安全網絡安全
  • 新媒體與短視頻運營新媒體
  • 直播帶貨直播帶貨
  • 智能機器人軟件開發智能機器人
 

快速通道fast track

近期開班時間TIME

主站蜘蛛池模板: 岛国大片免费观看| 紫黑粗硬狂喷浓精| 欧美性受xxxx白人性爽| 在线网站你懂得| 亚洲色偷偷色噜噜狠狠99网| www国产91| 男女性潮高清免费网站| 女人脱裤子让男生桶的免费视频| 又大又粗又爽a级毛片免费看| 中文字幕久久综合| 精品无码av无码免费专区| 性xxxxfreexxxxx国产| 动漫乱人伦视频在线观看| wwwxxx在线观看| 激情综合色五月丁香六月欧美| 在线视频www| 亚洲成av人片在线观看www | 国产精品亚洲四区在线观看| 最近中文字幕资源8| 国产成人影院在线观看| 久久精品一区二区影院| 调教扩张尿孔折磨失禁| 护士撩起裙子让你桶的视频| 别揉我胸啊嗯上课呢的作文| a级毛片100部免费观看| 欧美日韩国产剧情| 国产熟睡乱子伦视频观看软件| 久久综合AV免费观看| 蜜挑成熟时k8经典网| 岛国视频在线观看免费播放| 亚洲综合久久精品无码色欲| 18精品久久久无码午夜福利 | 在线欧美日韩精品一区二区| 亚洲尹人九九大色香蕉网站| 国产精品吹潮香蕉在线观看| 日本xxxwww| 你懂的网址免费国产| 6080yy成人午夜电影| 日韩内射美女片在线观看网站| 啊灬啊灬别停啊灬用力啊免费| bt天堂在线最新版在线|