昨天做移動項目是,遇到這樣一個案例,如圖,圖片容器隨着視口寬度進行自由拉伸擴張,圖片不定寬高,垂直居中:
當時做這個布局的時候,我一直想到用display:table-cell通過vertical-align:middle,來實現居中,可以當我在同一個節點用position:absolute,會導致此居中問題失效。
最后想到的解決方案,案例如下,不定寬高垂直居中:
<!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8"> <title></title> <meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1.0, maximum-scale=1.0"> <style type="text/css"> p{margin:0;padding:0} .wrap,.wrap1{ width:30%; padding-top:30%; background:#eee; position:relative; } .wrap p,.wrap1 p{ position:absolute; top:0; left:0; width:100%; height:100%; } .wrap p img{ max-width:100%; max-height:100%; position:absolute; top:50%; left:50%; -webkit-transform-origin:50% 50%; -webkit-transform:translate3d(-50%,-50%,0); } .wrap1 p{text-align:center;font-size:0;} .wrap1 p:after{ width:0; height:100%; display:inline-block; vertical-align:middle; content:""; } .wrap1 p img{ display:inline-block; max-width:100%; max-height:100%; vertical-align:middle; margin:0 auto; } </style> </head> <body> <h2>第一種方案</h2> <div class="wrap"> <p> <img src="img/download.jpg" alt="" /> </p> </div> <h1>111</h1> <div class="wrap"> <p> <img src="img/download1.jpg" alt="" /> </p> </div> <h2>第二種方案</h2> <div class="wrap1"> <p> <img src="img/download.jpg" alt="" /> </p> </div> <h1>111</h1> <div class="wrap1"> <p> <img src="img/download1.jpg" alt="" /> </p> </div> <div id="demo"> <p>水平垂直居中的隨意內容</p> </div> </body> </html>
下面我們將分別介紹三種垂直居中的解決方案:
已咀嚼一下以前的幾個老知識點:
1.水平居中知識點
text-align:center
對於水平居中可能不需要太多的介紹,所有主流瀏覽器均支持 text-align 屬性,只需要取值 center 即可;
2.vertical-align知識點
vertical-align適用於 inline level, inline-block level 及 table-cells 元素上
所有主流瀏覽器均支持 vertical-align 屬性,所以使用該屬性來實現垂直居中是一個不錯的想法;
一、利用display:table-cell;vertical-align:middle;進行不定高度,垂直居中 例子demo
<div id="demo"> <p>水平垂直居中的隨意內容</p> </div> #demo{ display:table; width:500px; margin:10px auto; background:#eee; } #demo p{ display:table-cell; height:100px; vertical-align:middle; }
既然table能實現,自然也就會想到將 display 設置為table系value來實現。當然,該方案是有局限性的,因為IE8以下的瀏覽器不支持 display 的table系value,所以你只能在IE8及以上瀏覽器以及非IE瀏覽器下才能看到效果;
二、利用display:inline-block;vertical-align:middle;進行不定高度,垂直居中 例子DEMO
<div id="demo"> <p>水平垂直居中的隨意內容</p> </div> #demo{ height:100px; text-align:center; } #demo:after{ display:inline-block; width:0; height:100%; vertical-align:middle; content:''; } #demo p{ display:inline-block; vertical-align:middle; }
這里有一點需要非常注意:參照以上代碼,如果我們的內容容器p的寬度為100%時,就會導致#demo:after被擠出不在一行,這個是由於inline元素間隔導致的,可以設置font:0消除,如果為了保持全兼容,可以不用偽類,使用span標簽去替代。
完美解決方案:例子demo
<div id="demo"> <p>這是一個終極實現的水平垂直居中實例</p> <!--[if lt IE 8]><span></span><![endif]--> </div> #demo{ height:100px; text-align:center; font-size:0; //注意這里是去除文字間隔,放在內容寬度為100%時擠出換行 } #demo:after,#demo span{ display:inline-block; *display:inline; *zoom:1; width:0; height:100%; vertical-align:middle; } #demo:after{ content:''; } #demo p{ display:inline-block; *display:inline; *zoom:1; vertical-align:middle; font-size:16px; }
三、利用translate3d(-50%,-50%,0)實現垂直居中,只支持高版本
<style type="text/css"> .main{width:600px;height:600px;position:relative} .box{position:absolute;top:50%;left:50%;-webkit-transform-origin:50% 50%;-webkit-transform:translate3d(-50%,-50%,0)} //原理有點跟 top:50%;left:50%;margin:-height/2 0 0 -width/2類似,這種是要知道高度,但是這個不需要 </style> <div class="main"> <div class="box">555666</div> </div>
四、利用兩級嵌套,兩次left,top實現居中
<style type="text/css"> html,body{width: 100%; height: 100%; margin: 0; padding: 0;} .wrp{position: fixed; width: 100%; height: 100%; left: 0; top: 0; background-color: rgba(0,0,0,.5);} .box{position: absolute; left: 50%; top: 50%;} .box2{position: relative; left: -50%; top: -50%; background-color: #f60000; color: #fff; padding: 10px;} </style> <div class="wrp"> <div class="box"> <div class="box2"> sssssfdsfd </div> </div> </div>
利用兩個不定寬高的div相嵌。外圍的div用absolute定位,left:50%,top:50%。這樣外圍的div的左上角處於水平垂直居中狀 態。內部的div使用relative定位,這樣可以利用自身的寬高撐開外圍的div,再用left:-50%,top:-50%;(用margin- left,margin-top也可以,就是利用取值的是參照外圍div的寬高的原理)實現內部div的幾何中心與外圍的div左上角重合。這樣實現了垂 直水平劇中。這個原理有點像使用translate(-50%,-50%)來實現水平垂直居中,不過我用的是css1.0的代碼,所以兼容性很好 IE6.0~IE11 chrome,firefox都可以
五、使用 box-align and box-pack 屬性居中,必須在box-align控制垂直方向,box-pack水平方向,但是這種只能在display:box彈性盒子容器下使用
兼容性,firefox,chrome,ios7以上,andriod4.0以上
親測:小米MI2CS、小米MI3/魅族魅藍note、榮耀6、iphone4s、iphone6 plus 通過。
<!DOCTYPE html> <html> <head> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" /> <meta name="apple-mobile-web-app-capable" content="yes"> <meta name="apple-mobile-web-app-status-bar-style" content="black"> <meta name="format-detection" content="telephone=no"> <meta http-equiv="x-dns-prefetch-control" content="on" /> <style> div.flexbox { width:350px; height:400px; border:1px solid black; /* Firefox */ display:-moz-box; -moz-box-pack:center; -moz-box-align:center; /* Safari, Chrome, and Opera */ display:-webkit-box; /**水平居中**/ -webkit-box-pack:center; /***垂直居中**/ -webkit-box-align:center; /* W3C */ display:box; box-pack:center; box-align:center; } .box{padding:10px;background:orange} </style> </head> <body> <!---flexbox做居中---> <h2>使用 box-align and box-pack 屬性居中</h2> <div class="flexbox"> <div class="box"> <p>我是居中對齊的。</p> <p>我不帥,我不帥。</p> </div> </div> <br /> <br /> <br /> <br /> <h2>使用 box-align and align-items 屬性居中</h2> <!---flexbox做居中---> <div class="boxflex"> <div class="boxlf"></div> <div class="box"> <p>我是居中對齊的ss。</p> <p>我不帥,我不帥。</p> </div> </div> <style type="text/css"> .boxflex{ display:-webkit-box; display:-moz-box; display:-ms-box; display:-o-box; display:box; width:350px; height:200px; -webkit-box-align:center; -webkit-align-items: center; -ms-flex-align: center; align-items: center; } .boxlf{ width:20px; height:100%; background:red; } .boxflex .box{ /*display:block;*/ -webkit-box-flex: 1; -moz-box-flex: 1; box-flex: 1; } </style> <p><b>注釋:</b>IE 不支持 box-pack 和 box-align 屬性。</p> </body> </html>
資料參考:
未知尺寸元素水平垂直居 http://demo.doyoe.com/css/alignment/