flex上下固定中間滾動布局


傳統 pc 端中,子容器高度超出父容器高度,通常使用 overflow:auto 可出現滾動條拖動顯示溢出的內容,而移動web開發中,由於瀏覽器廠商的系統不同、版本不同,導致有部分機型不支持對彈性滾動,從而在開發中制造了所謂的 BUG。

 

上圖如果在PC端中,我們可以利用 position:fixed 和 overflow:auto 進行簡單的布局實現我們需要的效果,而在手機端遇到的問題如下:

  • ios4 和 android2.2 以下不支持 position:fixed
  • ios 和 android2.3 以下不支持 overflow:auto
  • ios4 和 android 不支持 overflow-scrolling

最嚴重的結果是:滾動區域內容無法拖動

對於 ios4 和 android2.2 以下不支持 position:fixed 的問題,有2種布局方法可以替代。

布局一: 定義頁面整體高度為100%,然后使用 position:absolute 布局可解決

復制代碼
/*
<!--absolute布局 [[ -->
<body>
<div class="wrap">
    <div class="header">header</div>
    <div class="main">
     彈性滾動區域
    </div>
    <div class="footer">footer</div>
</div>
</body>
<!--absolute布局 ]] -->
*/
html,body{height:100%;}
.wrap{width:100%;}
.header,.footer{height:40px;line-height:40px;background-color:#D8D8D8;text-align:center;}
.header{position: absolute;top:0;left:0;width:100%;}
.footer{position: absolute;bottom:0;left:0;width:100%;}
.main{position:absolute;z-index:1;top:40px;left:0;bottom:40px;width:100%;}
復制代碼
復制代碼

 

布局二: 定義頁面整體高度為100%,然后使用 display:flex 布局可解決

復制代碼
復制代碼
/*
<!-- flex布局 [[ -->
<body>
<div class="wrap">
      <div class="header">header</div>
      <div class="main">
       彈性滾動區域
      </div>
      <div class="footer">footer</div>
</div>
</body>
<!-- flex布局 ]] -->
*/
html,body{height:100%;}
.wrap{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;width:100%;height:100%;}
.header,.footer{height:40px;line-height:40px;background-color:#D8D8D8;text-align:center;}
.main{-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1;width:100%;}
復制代碼
復制代碼

 

那么剩下的主要問題是子容器高度超出父容器高度,子容器內容如何彈性滾動。

對於如何使用彈性滾動,這里並沒有最好的方案,具體看產品的用戶群、產品的定位等,簡單介紹下:

方案一: overflow:auto和-webkit-overflow-scrolling: touch

適合場景:產品的用戶群大多為 ios5+、android4+ 用戶,建議采用 overflow-scrolling 做差異化體驗,畢竟 iscroll4.js 在 android 機器下體驗不順暢,另外還加載了 10K 多的 js 代碼。

overflow:auto 寫法在 winphone8 和 android4+ 上有用。ios5+ 版本增加了一個新的屬性:overflow-scrolling 這個屬性可以激活平滑滾動,效果不錯。

.css{
overflow:auto;/* winphone8和android4+ */
-webkit-overflow-scrolling: touch; /* ios5+ */
}

flex體驗demo:

http://1.peunzhang.sinaapp.com/demo/flex/flex-t-m-b.html

 

 

 

摘自:http://www.cnblogs.com/adengweb/p/5421669.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM