91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

當position:sticky遇到bootstrap浮動布局時候的注意事項

發布時間:2021-01-19 11:47:55 來源:億速云 閱讀:250 作者:小新 欄目:web開發

小編給大家分享一下當position:sticky遇到bootstrap浮動布局時候的注意事項,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

當第一次接觸到 position:sticky 這個屬性,我就意識到之前的不少 js 場景可以用這個 css 屬性去改寫。譬如 網站 右側的不少廣告,滾動上去后需要 fixed,完全就是 sticky 的應用啊。

今天要說的是 文章詳情頁 右側的目錄欄,當頁面下滑的時候,它也會固定到頁面頂部,之前是用 js 去監聽 scroll 事件,然后根據位置進行判斷,toggle fixed 的方案,出于一些原因,決定對它用 sticky 去重寫。

幾下就寫完了,去掉滾動事件監聽,然后將菜單元素 .post-nav 加上 position:sticky; top:0 樣式,但是,不起效!

wtf! 百思不得其解,我開始搜索原因。在 so 搜到了 這個,說到可能是元素的父級元素有對 overflow 屬性進行處理,比如加了什么 overflow:hidden 啥的,但是看了下,并沒有這種情況。

然后我猜想會不會是 bootstrap 布局的問題(事實上確實有關系),寫下 demo:

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <link href="//cdn.bootcss.com/bootstrap/4.1.1/css/bootstrap.min.css" rel="stylesheet">
  <style>
    body {font-size: 50px; font-weight: 900;}
    .main {height: 2000px; background: #eee}
    .menu {height: 200px; background: yellow}
    .ad {height: 200px; background: red; position: sticky; top: 0px;}
    .guess {height: 200px; background: blue;}
  </style>
</head>
<body>
<p class="container">
  <p class="row">
    <p class="col-md-8 main">content</p>
    <p class="col-md-4">
      <p class="menu">menu</p>
      <p class="ad">ad</p>
      <p class="guess">others</p>
    </p>
  </p>
</p>
</body>
</html>

但是沒問題,突然想到網站用的 bootstrap 版本是 3.x,然后改成 3.3.7 的版本,這時候問題就出來了。

這時候問題就比較好定位了,4.x 用的是 flex 布局,而 3.x 還是 float 浮動布局,問題應該是出在這里了。

最終代碼(參考 這個 issue):

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <link href="//cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
  <style>
    body {font-size: 50px; font-weight: 900;}
    .main {height: 2000px; background: #eee}
    .side {height: 2000px;}
    .menu {height: 200px; background: yellow}
    .ad {height: 200px; background: red; position: sticky; top: 0px;}
    .guess {height: 200px; background: blue;}
  </style>
</head>
<body>
<p class="container">
  <p class="row">
    <p class="col-md-8 main">content</p>
    <p class="col-md-4 side">
      <p class="menu">menu</p>
      <p class="ad">ad</p>
      <p class="guess">others</p>
    </p>
  </p>
</p>
</body>
</html>

對應到開始的問題上,因為 menu 是屬于 .col-md-3 元素的,所以右邊的 .col-md-3 需要和左邊的 .col-md-9 保持高度一致即可,加上這行代碼:

$('.side').height($('.main').height())

因為左邊的內容區域有圖片的延遲加載,所以這行代碼需要持續執行:

$(window).scroll(function() { 
 $('.side').height($('.main').height())

 // other code 
 // ...

})

以上是“當position:sticky遇到bootstrap浮動布局時候的注意事項”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平凉市| 长春市| 武强县| 竹溪县| 定结县| 循化| 乌拉特中旗| 永新县| 滕州市| 三门县| 湘阴县| 九江市| 佛教| 张家界市| 鞍山市| 类乌齐县| 南汇区| 三江| 桦甸市| 鹤山市| 喀喇沁旗| 沙洋县| 察隅县| 萨迦县| 和硕县| 乾安县| 本溪市| 曲阜市| 富平县| 九寨沟县| 城固县| 凤庆县| 通海县| 白朗县| 孟州市| 龙泉市| 法库县| 沿河| 剑河县| 邳州市| 南木林县|