婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 討論CSS中的各類居中方式

討論CSS中的各類居中方式

熱門標簽:山東電銷機器人軟件 申請400電話移動 常州電話外呼系統招商 洛陽防封卡外呼系統廠家 上海400電話辦理到易號網 智能語音電銷機器人客戶端 成都企業外呼系統 南通電銷外呼系統軟件 廣州防封電銷機器人廠家

今天主要談一談CSS中的各種居中的辦法。
首先是水平居中,最簡單的辦法當然就是

復制代碼 代碼如下:
margin:0 auto;

也就是將margin-left和margin-right屬性設置為auto,從而達到水平居中的效果。

那么其他的辦法呢?容我一一道來:

line-height

首先介紹文字的水平居中方法:

復制代碼 代碼如下:
div class="wrap">劉放/div>

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

復制代碼 代碼如下:
.wrap{
  line-height: 200px;/*垂直居中關鍵*/
  text-align:center;

  height: 200px;
  font-size: 36px;
  background-color: #ccc;
}

效果如下:

padding填充

利用padding和background-clip配合實現div的水平垂直居中:

復制代碼 代碼如下:
div class="parent">
  div class="children">/div>
/div>

通過backgroun-clip設置為content-box,將背景裁剪到內容區外沿,再利用padding設為外div減去內div的差的一半,來實現:

.parent{
 margin:0 auto;
 width:200px;
 height:200px;
 background-color:red;
}
.children {
 width: 100px;
 height: 100px;
 padding: 50px;
 background-color: black;
 background-clip:content-box;/*居中的關鍵*/

效果如下:

margin填充

接下來介紹margin填充的方式來實現水平垂直居中。
首先我們還是定義父子div:

div class="parent">
  div class="children">/div>
/div>

這里我們利用將子div的margin-top設置為父div高度減去子div高度的一半,然后再通過overflow設置為hidden來觸發父div的BFC,LESS代碼如下:

@parentWidth:200px;
@childrenWidth:50px;
.parent {
 margin:0 auto;
 height:@parentWidth;
 width:@parentWidth;
 background: red;
 overflow:hidden;/*觸發BFC*/
}
.children {
 height:@childrenWidth;
 width:@childrenWidth;
 margin-left:auto;
 margin-right:auto;
 margin-top: (@parentWidth - @childrenWidth) / 2;
 background:black;
}

最后得到居中效果如下:

absolute定位

利用position:absolute搭配top,left 50%,再將margin設為負值也可以對div進行水平垂直居中,首先還是需要定義父子div:

復制代碼 代碼如下:
div class="parent">
  div class="children">/div>
/div>

然后設置相應的css:

.parent {
 position:relative;
 margin:0 auto;
 width:200px;
 height:200px;
 background-color:red;
}
.children {
 position:absolute; 
 left:50%; 
 top:50%; 
 margin:-25px 0 0 -25px ;
 height:50px;
 width:50px;
 background-color: black;
}

其中的margin中的值為該div寬度的一半,最后效果圖:

text-align居中

眾所周知,text-align可以使得一個div中的內容水平居中。但是如果是要將該div中的子div居中呢?可以將子div的display設為inline-block。

.parent {
 text-align:center;
 margin:0 auto;
 width:200px;
 height:200px;
 background:red;
}
.children {
 positiona;absolute;
 margin-top:75px;
 width:50px;
 height:50px;
 background: black;
 display:inline-block;/*使其父元素text-align生效*/
}

圖片居中

一般的圖片居中都是和text-align一樣,將圖片包裝在一個div中,將該div的text-align設為center即可。
可以參考下面的鏈接:
個人站點

有一種特殊的方式,利用了一個圖片進行占位,以讓父容器獲得高寬,從而讓進行-50%偏移的圖片能有一個參照容器作百分比計算。優點是可以不知道圖片的大小,隨便放張尺寸不超過父容器的圖片上去都能做到居中。另外,兼容性好,IE6都是能順利兼容的。代碼如下:

復制代碼 代碼如下:
div class="parent">
  p>
    img class="hidden-img" src="http://nec.netease.com/img/s/1.jpg" alt="" />
    img class="show-img" src="http://nec.netease.com/img/s/1.jpg" alt="" />/p>
/div>


.parent {
 position:relative;
 width:100%;
 height:200px;
 background:red;
}
p {
 position:absolute;
 top:50%;
 left:50%;
}
.hidden-img {
 visibility:hidden;
}
.show-img {
 position:absolute;
 right:50%;
 bottom:50%;
}

效果如下:

transform居中

上面講到的div居中的例子中,div的寬度都是固定的,然而實際項目中,有可能遇到不定寬的div,特別是響應式或者移動端的設計中,更加常見。所以下面介紹一種不需要定寬的div水平垂直居中方法。
先上代碼:

復制代碼 代碼如下:
div class="parent">
  div class="children">
    div class="children-inline">我是水平垂直居中噢!/div>
  /div>
/div>

.parent {
 float: left;
 width: 100%;
 height: 200px;
 background-color: red;
}
.children {
 float:left;
 position:relative;
 top:50%;
 left:50%;
}
.children-inline {
 position: relative;
 left: -50%;
 -webkit-transform : translate3d(0, -50%, 0);
 transform : translate3d(0, -50%, 0);
 background-color: black;
 color:white;
}


效果如下:

 

首先我們利用float,將需要居中的div的父div也就是children的寬度收縮,然后left:50%,將children的左邊與水平中線對齊。這個時候,還沒有真正居中,我們需要將children-inner左移動-50%,這樣就水平居中了。
再來說說垂直方向,先將children的top設為50%,然后其上邊和垂直中線對齊了,同樣,我們需要將children-inner上移動-50%。但是這個50%是計算不出來的,所以我們用到了transform : translate3d(0, -50%, 0);
這個方法非常好用噢。

flex居中

最后來介紹一下CSS3中的display:flex來實現的水平垂直居中的方法。

復制代碼 代碼如下:
div class="parent">
  div class="children">我是通過flex的水平垂直居中噢!/div>
/div>

html,body{
 width: 100%;
 height: 200px;
}
.parent {
 display:flex;
 align-items: center;/*垂直居中*/
 justify-content: center;/*水平居中*/
 width:100%;
 height:100%;
 background-color:red;
}
.children {
 background-color:blue;
}

效果如下:

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

以上就是本文的全部內容,希望大家可以喜歡。

您可能感興趣的文章:
  • CSS如何使DIV層居中
  • CSS解決未知高度垂直居中的問題
  • css布局網頁水平居中常用方法
  • css實現文字垂直居中的代碼
  • css支持標準的圖片垂直居中
  • js+CSS實現彈出居中背景半透明div層的方法

標簽:廣安 滄州 混顯 鶴壁 萊蕪 賀州 邵陽 貴州

巨人網絡通訊聲明:本文標題《討論CSS中的各類居中方式》,本文關鍵詞  討論,CSS,中的,各類,居中,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《討論CSS中的各類居中方式》相關的同類信息!
  • 本頁收集關于討論CSS中的各類居中方式的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 九台市| 广宗县| 开封县| 瓦房店市| 赣州市| 武陟县| 宿迁市| 沙坪坝区| 沾益县| 东乌珠穆沁旗| 临武县| 南雄市| 德庆县| 涟源市| 治县。| 高雄市| 郴州市| 德钦县| 咸丰县| 油尖旺区| 雷州市| 巴林左旗| 鱼台县| 白城市| 全州县| 竹溪县| 红原县| 绥阳县| 读书| 中方县| 阳西县| 徐汇区| 无为县| 喀喇沁旗| 苍南县| 班戈县| 塔河县| 松桃| 尉氏县| 庆安县| 桓台县|