整合營銷服務商

          電腦端+手機端+微信端=數(shù)據(jù)同步管理

          免費咨詢熱線:

          學會這幾種方法,css居中其實很簡單

          們在使用css來布局時經(jīng)常需要進行居中,有時一個屬性就能搞定,有時則需要一定的技巧才能兼容到所有瀏覽器,利用css來實現(xiàn)對象的垂直居中有許多不同的方法,比較難的是應該選擇哪種正確的方法。比如我們都知道 margin:0 auto;的樣式能讓元素水平居中,而margin: auto;卻不能做到垂直居中……下面就css居中的一些常用方法做個集中的介紹。

          首先是水平居中,最簡單的辦法當然就是:

          margin:0 auto;

          文字的水平居中方法:

          利用line-height設為height的一樣即可:

          eg:

          .div {

          width:200px;

          height: 200px;

          line-height: 200px;/*實現(xiàn)垂直居中的關鍵*/

          text-align:center;

          font-size: 36px;

          background-color: #ccc;

          }

          絕對定位居中

          父容器元素:position: relative,子元素:position:absolute;

          eg:

          <div class="box">

          <div class="content"></div>

          </div>

          <style>

          .box{position:relative;width:200px;height:200px;background:#999;}

          .content{

          width: 50%;

          height: 50%;

          overflow: auto;

          margin: auto;

          position: absolute;

          top: 0; left: 0; bottom: 0; right: 0;

          background:#C9F;}

          </style>

          效果如下所示:

          !注意:高度必須定義,建議加 overflow: auto,防止內(nèi)容溢出。

          flex居中

          介紹一下CSS3中的display:flex來實現(xiàn)的水平垂直居中的方法。

          eg:

          <div class="parent">

          <div class="children">我是通過flex的水平垂直居中噢!</div>

          </div>

          <style>

          .parent {

          display:flex;

          align-items: center;/*垂直居中*/

          justify-content: center;/*水平居中*/

          width:200px;

          height:200px;

          background-color:green;

          }

          .children {

          background-color:blue;

          color:#FFF;

          }

          </style>

          效果如下所示:

          這種方式最為簡便,就是兼容性不好,不過隨著時間的前進,各大瀏覽器一定會都兼容的。

          里是工作狂的聚集地

          職場

          學術

          新媒體

          設計

          極客

          專門治愈處女座強迫癥。

          本文為CSS入門

          翻譯 redman9

          原載CSS-Trick

          人們經(jīng)常抱怨在 CSS 中居中元素的問題,其實這個問題并不復雜,只是因為方法眾多,需要根據(jù)情況從眾多方法中選取一個出來。接下來,我們做一個 "決定樹" 來幫我們把問題變的簡單一點。首先你需要居中:

          —— 水平 ——

          ?需要居中inline或者inline-*元素(如文字或者鏈接)?

          ? 需要居中block類的元素?

          ? 需要居中多個block元素?

          —— 垂直 ——

          ?需要居中inline或者inline-*元素(如文字或者鏈接)?

          ?需要居中block類的元素?

          ——既水平又垂直 ——

          ?固定寬高

          ?不固定寬高

          ?使用flexbox

          ● ● ●

          水平居中

          水平居中inline或者inline-*元素

          你可以輕松的在一個block元素中水平居中一個inline元素,以下代碼對inlineinline-blockinline-tableinline-flex等有效。

          .parent {
          text-align: center;
          }

          水平居中block類的元素

          block元素被設定固定寬度的情況下,可以使用設置元素margin-leftmargin-right的值為auto的方法實現(xiàn)水平居中。

          .child {
          width: 400px;
          margin: 0 auto;
          }

          水平居中多個block類的元素

          通過inline-block實現(xiàn)

          .parent {
          text-align: center;
          }
          .child {
          display: inline-block;
          text-align: left;
          }

          通過flexbox實現(xiàn)

          .parent {
          display: flex;
          justify-content: center;
          }

          ● ● ●

          垂直居中

          垂直居中inline或者inline-*元素

          【單行】

          inline/text元素可以簡單的用設置相同的上下padding值達到垂直居中的目的。

          .center {
          pading-top: 30px; padding-bottom: 30px;
          }

          如果因為某種原因不能使用padding的方法,你還可以設置line-height等于height來達到目的。

          .center {
          height: 100px; line-height: 100px; white-space: nowrap;
          }

          【多行】

          相同的上下padding也可以適用于此種情況,如果不能生效,你可以嘗試將該元素的父元素的display設置為table,同時該元素的display設置為table-sell,然后設置vertical-align

          .parent {
          display: table;
          width: 200px; height: 400px;
          } .child {
          display: table-cell;
          vertical-align: middle;
          }

          如果上述方法不能使用,你可以嘗試使用flexbox,一個單獨的flexbox子元素可以輕易的在其父元素中居中。謹記,這種方法需要父元素有固定的高度。

          .parent {
          display: flex; justify-content: center;
          flex-direction: column; height: 400px;
          }

          如果上述兩種方式均不能使用,你可以使用“幽靈元素”技術,這種方法采用偽元素::before撐開高度 ,文字垂直居中。

          .parent {
          position: relative;
          } .parent::before {
          content: " "; display: inline-block; height: 100%; width: 1%; vertical-align: middle;
          } .child {
          display: inline-block;
          vertical-align: middle; }

          垂直居中block類的元素

          【已知元素高度】

          .parent { 
          position: relative; } .child {
          position: absolute;
          top: 50%;
          height: 100px;
          margin-top: -50px; /* account for padding and border if not using box-sizing: border-box; */
          }

          【未知元素高度】

          .parent {
          position: relative; } .child {
          position: absolute;
          top: 50%;
          transform: translateY(-50%); }

          【使用flexbox

          .parent {
          display: flex;
          flex-direction: column;
          justify-content: center; }

          ● ● ●

          既水平又垂直

          【固定寬高】

          .parent {
          position: relative; } .child {
          width: 300px;
          height: 100px;
          padding: 20px;
          position: absolute;
          top: 50%;
          left: 50%;
          margin: -70px 0 0 -170px; }

          【不固定寬高】

          .parent { position: relative; } .child { position: absolute; top: 50%; left: 50%;
          transform: translate(-50%, -50%); }

          【使用flexbox

          .parent { display: flex; justify-content: center; align-items:center; }
          <div id="parent">
          <!-- 定義子級元素 -->
          <div id="child">居中布局</div>
          </div>

          過以下CSS樣式代碼實現(xiàn)水平方向居中布局效果

          .parent{position:relative;}
          .child{position:absolute;left:50%;transform: translateX(-50%)}

          優(yōu)點:

          父級元素是否脫離文檔流, 不影響子集元素水平居中效果

          缺點:transform屬性是CSS3中新增屬性, 瀏覽器支持情況不好


          主站蜘蛛池模板: 一区二区三区视频在线播放| 国产一区中文字幕在线观看| 亚洲AV无码一区二区二三区入口| 国产精品亚洲一区二区三区在线| 高清国产AV一区二区三区| 91久久精品一区二区| 亚洲AV日韩AV一区二区三曲| 国产女人乱人伦精品一区二区| 99精品久久精品一区二区| 久久亚洲日韩精品一区二区三区| 国产精品一区二区毛卡片| 国产另类ts人妖一区二区三区| 日韩爆乳一区二区无码| 无码精品不卡一区二区三区| 国产美女露脸口爆吞精一区二区 | 精品少妇ay一区二区三区 | 一区一区三区产品乱码| 国产一区二区精品久久岳√| 国产在线无码视频一区二区三区| 无码精品尤物一区二区三区| 精品成人av一区二区三区| 精品深夜AV无码一区二区老年| 波多野结衣av高清一区二区三区| 无码aⅴ精品一区二区三区浪潮 | 中文字幕一区在线| 亚洲国产日韩在线一区| 亚洲性日韩精品一区二区三区| 亚洲一区欧洲一区| 国产在线精品一区二区三区直播 | 男人的天堂av亚洲一区2区| 变态拳头交视频一区二区| 国产视频一区二区在线观看| 末成年女AV片一区二区| 亚洲国产精品一区二区第四页| 一区二区和激情视频| 亚洲AV日韩AV天堂一区二区三区| 一区二区三区在线播放视频| 国产怡春院无码一区二区 | 亚洲AV无码一区二区三区电影| 夜夜添无码一区二区三区| 福利片福利一区二区三区|