明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

當(dāng) position:sticky 遇到 bootstrap 浮動(dòng)布局時(shí)候的踩坑記錄

[摘要]當(dāng)?shù)谝淮谓佑|到 position:sticky 這個(gè)屬性,我就意識(shí)到之前的不少 js 場(chǎng)景可以用這個(gè) css 屬性去改寫。譬如 網(wǎng)站 右側(cè)的不少廣告,滾動(dòng)上去后需要 fixed,完全就是 sticky 的應(yīng)用啊。今天要說的是 文章詳情頁 右側(cè)的目錄欄,當(dāng)頁面下滑的時(shí)候,它也會(huì)固定到頁面頂部,之前是...
當(dāng)?shù)谝淮谓佑|到 position:sticky 這個(gè)屬性,我就意識(shí)到之前的不少 js 場(chǎng)景可以用這個(gè) css 屬性去改寫。譬如 網(wǎng)站 右側(cè)的不少廣告,滾動(dòng)上去后需要 fixed,完全就是 sticky 的應(yīng)用啊。

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

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

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

然后我猜想會(huì)不會(huì)是 bootstrap 布局的問題(事實(shí)上確實(shí)有關(guān)系),寫下 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>

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

這時(shí)候問題就比較好定位了,4.x 用的是 flex 布局,而 3.x 還是 float 浮動(dòng)布局,問題應(yīng)該是出在這里了。

最終代碼(參考 這個(gè) 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>

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

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

因?yàn)樽筮叺膬?nèi)容區(qū)域有圖片的延遲加載,所以這行代碼需要持續(xù)執(zhí)行:

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

 // other code 
 // ...

})

總結(jié):以上就是本篇文的全部?jī)?nèi)容,希望能對(duì)大家的學(xué)習(xí)有所幫助。更多相關(guān)教程請(qǐng)?jiān)L問 HTML視頻教程!

相關(guān)推薦:

php公益培訓(xùn)視頻教程

以上就是當(dāng) position:sticky 遇到 bootstrap 浮動(dòng)布局時(shí)候的踩坑記錄的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


網(wǎng)站建設(shè)是一個(gè)廣義的術(shù)語,涵蓋了許多不同的技能和學(xué)科中所使用的生產(chǎn)和維護(hù)的網(wǎng)站。