居中设置
- 水平居中設置
?水平居中設置-行內元素
如果被設置元素為文本、圖片等行內元素時,水平居中是通過給父元素設置 text-align:center 來實現的。
例:div{
border:1px solid red;
margin:20px;
text-align:center;
}
<div class="txtCenter">我想要在父容器中水平居中顯示。</div>
div是“我想要在父容器中水平居中顯示”這個文本的父元素。
水平居中設置-定寬塊狀元素
定寬塊狀元素:塊狀元素的寬度width為固定值。
div{
border:1px solid red;
width:200px;
margin:30px auto;
}
<div>我是定寬塊狀元素,我要水平居中顯示。</div>
水平居中總結-不定寬塊狀元素方法
不定寬度的塊狀元素有三種方法居中(這三種方法目前使用的都很多):
1.加入 table 標簽
2.設置 display: inline 方法:與第一種類似,顯示類型設為 行內元素,進行不定寬元素的屬性設置
3.設置 position:relative 和 left:50%:利用 相對定位 的方式,將元素向左偏移 50% ,即達到居中的目的
方法一:table標簽的長度自適應性---即不定義其長度也不默認父元素body的長度(table其長度根據其內文本長度決定),因此可以看做一個定寬度塊元素,然后再利用定寬度塊狀居中的 margin的方法,使其水平居中。
第一步:為需要設置的居中的元素外面加入一個 table 標簽 ( 包括 <tbody>、<tr>、<td> )。
第二步:為這個 table 設置“左右 margin 居中”(這個和定寬塊狀元素的方法一樣)。
例:.wrap{
?? margin:auto;
}
<table> <tbody> <tr><td> <ul> //<ul>的作用為在行前面空格
<div class="wrap">
設置我所在的div容器水平居中?
</div>
</ul> </td></tr> ? ?</tbody> ?</table>
方法二:例:
<div class="container">
<ul>
<li><a href="#">1</a></li>
<li><a href="#">2</a></li>
<li><a href="#">3</a></li>
</ul>
</div>
.container{
text-align:center;
}
.container ul{
list-style:none;
margin:0; // 消除文本與div邊框之間的間隙
padding:0;// 消除文本與div邊框之間的間隙
display:inline;
}
.container li{
margin-right:8px; //設置li文本之間的間隔
display:inline;
}
與第一種方法相比:
優點:不用增加無語義標簽
缺點:它將塊狀元素的 display 類型改為 inline,變成了行內元素,所以少了一些功能,比如設定長度值。
方法三:通過給父元素設置 float,然后給父元素設置 position:relative 和 left:50%,子元素設置 position:relative 和 left: -50% 來實現水平居中。
!!!我們可以這樣理解:假想wrap層中間有條平分線將wrap層平均分為兩份,wrap-center層的css代碼是將wrap-center層的最左端與wrap層的平分線對齊;而"學習"層的css代碼則是將"學習"層的平分線與wrap-center層的最左端(也是wrap層的平分線)對齊,從而實現"學習"層的居中。
我的理解但不知道對不對:浮動為左的情況下,wrap-center向右移動了它父類的50%(即50%),"學習"向左移動了它父類的50%(即-50%)
代碼如下:
.wrap{
float:left;
position:relative;
left:50%;
}
.wrap-center{
position:relative;
left:-50%;
}
<div class="wrap">
<div class="wrap-center">學習</div>
</div>
- 垂直居中
垂直居中-父元素高度確定的單行文本
分兩種情況:父元素高度確定的單行文本,以及父元素高度確定的多行文本。
方法是通過設置父元素的 height 和 line-height 高度一致來實現的。(height: 該元素的高度,line-height: 顧名思義,行高(行間距),指在文本中,行與行之間的 基線間的距離 )。
line-height 與 font-size 的計算值之差,在 CSS 中成為“行間距”。分為兩半,分別加到一個文本行內容的頂部和底部。
這種文字行高與塊高一致帶來了一個弊端:當文字內容的長度大于塊的寬時,就有內容脫離了塊。
垂直居中-父元素高度確定的多行文本?
方法一:使用插入 table (包括tbody、tr、td)標簽,同時設置 vertical-align:middle。
css 中有一個用于豎直居中的屬性 vertical-align,在父元素設置此樣式時,會對inline-block類型的子元素都有用。
例:
table td{height:500px;background:#ccc}
<table><tbody><tr><td class="wrap">
<div>
<p>看我是否可以居中。</p>
</div>
</td></tr></tbody></table>
td 標簽默認情況下就默認設置了 vertical-align 為 middle
問題:為什么要加<div>?
方法二(不建議使用):設置塊級元素的 display 為 table-cell(設置為表格單元顯示),激活 vertical-align 屬性
例:
.container{
height:300px;
background:#ccc;
display:table-cell;/*IE8以上及Chrome、Firefox*/
vertical-align:middle;/*IE8以上及Chrome、Firefox*/
}
<div class="container">
<div>
<p>看我是否可以居中。</p>
</div>
</div>
好處:不用添加多余的無意義的標簽。
缺點:它的兼容性不是很好,不兼容 IE6、7而且這樣修改display的block變成了table-cell,破壞了原有的塊狀元素的性質。
轉載于:https://www.cnblogs.com/Lune-Qiu/p/7305398.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
- 上一篇: POJ 1753 Flip Game 高
- 下一篇: 郑州刘庄地铁最晚几点