六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

當 position:sticky 遇到 bootstrap 浮動布局時候的踩坑記錄

[摘要]當第一次接觸到 position:sticky 這個屬性,我就意識到之前的不少 js 場景可以用這個 css 屬性去改寫。譬如 網站 右側的不少廣告,滾動上去后需要 fixed,完全就是 sticky 的應用啊。今天要說的是 文章詳情頁 右側的目錄欄,當頁面下滑的時候,它也會固定到頁面頂部,之前是...
當第一次接觸到 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 
 // ...

})

總結:以上就是本篇文的全部內容,希望能對大家的學習有所幫助。更多相關教程請訪問 HTML視頻教程

相關推薦:

php公益培訓視頻教程

以上就是當 position:sticky 遇到 bootstrap 浮動布局時候的踩坑記錄的詳細內容,更多請關注php中文網其它相關文章!


網站建設是一個廣義的術語,涵蓋了許多不同的技能和學科中所使用的生產和維護的網站。




主站蜘蛛池模板: 日韩手机专区 | 亚洲图片国产日韩欧美 | 婷婷综合缴情亚洲狠狠图片 | 手机看片日韩在线 | 日本中文字幕网址 | 武则天一级淫片免费 | 青青久精品观看视频最新 | 日本在线免费看片 | 亚洲欧美日韩精品久久久 | 日本视频播放免费线上观看 | 人妖欧美一区二区三区四区 | 日韩精品一区在线观看 | 午夜色视频在线观看 | 青娱乐免费视频 | 亚洲国产亚洲综合在线尤物 | 亚洲国产成人久久99精品 | 青青青青久在线观看视频 | 日本综合欧美一区二区三区 | 视频一区亚洲 | 日日摸夜夜摸人人嗷嗷叫 | 视频久久 | 日韩精品一区二区三区中文版 | 一级爱爱片 | 热热涩热热狠狠色香蕉综合 | 亚洲大尺度视频 | 亚洲综合亚洲综合网成人 | 日韩国产精品99久久久久久 | 色yeye免费视频免费看 | 青草伊人网 | 天天透天天干 | 一级做a爰片性色毛片视频图片 | 亚洲a视频在线观看 | 污视频免费在线观看 | 欧美一级一一特黄 | 亚洲成a人v欧美综合天 | 天天做天天爽爽快快 | 日日摸日日碰 | 天天躁日日躁狠狠躁视频下载播二 | 污污的视频在线播放 | 真实国产乱子伦精品一区二区三区 | 婷婷久久综合九色综合九七 |