不定寬高垂直居中分析


  昨天做移動項目是,遇到這樣一個案例,如圖,圖片容器隨着視口寬度進行自由拉伸擴張,圖片不定寬高,垂直居中:

  當時做這個布局的時候,我一直想到用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/

 


免責聲明!

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



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