多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

中國最全I(xiàn)T社區(qū)平臺 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2

css教程

CSS 教程

CSS 響應(yīng)式設(shè)計

CSS實例

拓展閱讀

學(xué)會這幾種方法css居中很簡單

閱讀 (2361)

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


首先是水平居中,最簡單的辦法當(dāng)然就是:

margin:0 auto;

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

文字的水平居中方法:

<div class="wrap">w3cschool</div>
利用line-height設(shè)為height的一樣即可:
.wrap{
  line-height: 200px;/*垂直居中關(guān)鍵*/
  text-align:center;
  height: 200px;
  font-size: 36px;
  background-color: #ccc;
}

效果如下所示:
文字居中

padding填充

利用padding和background-clip配合實現(xiàn)div的水平垂直居中:
<div class="parent">
  <div class="children"></div>
</div>
通過backgroun-clip設(shè)置為content-box,將背景裁剪到內(nèi)容區(qū)外沿,再利用padding設(shè)為外div減去內(nèi)div的差的一半,來實現(xiàn):
.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;/*居中的關(guān)鍵*/
效果如下所示:

padding填充

hacks, hacks(小技巧)

有許多 hacks ,負(fù) margin,影子元素 ::before 等。如果你的內(nèi)容不是固定大小的話,它們大部分是很脆弱的。


translate(-50%,-50%)

用 position 加 translate translate(-50%,-50%) 比較奇特,百分比計算不是以父元素為基準(zhǔn),而是以自己為基準(zhǔn)。

示例:

<style>
#ex3_container{
width:200px;
height:200px;
background-color:yellow;
position:relative;
}
#ex3_content{
left:50%; top:50%; 
transform:translate(-50%,-50%);
-webkit-transform:translate(-50%,-50%);
background-color:gray; color:white; position:absolute;
}
</style>
<div id="ex3_container"><div id="ex3_content">Hello World</div></div>

這個技巧相當(dāng)囂張,同樣適用于沒固定大小的內(nèi)容,min-width,max-height,overflow:scroll等。


絕對定位居中

父容器元素:position: relative

.Absolute-Center {
  width: 50%;
  height: 50%;
  overflow: auto;
  margin: auto;
  position: absolute;
  top: 0; left: 0; bottom: 0; right: 0;
}

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


視口居中

內(nèi)容元素:position: fixed,z-index: 999,記住父容器元素position: relative 

.Absolute-Center.is-Fixed {
  width: 50%;
  height: 50%;
  overflow: auto;
  margin: auto;
  position: fixed;
  top: 0; left: 0; bottom: 0; right: 0;
  z-index: 999;
}


響應(yīng)式

百分比寬高,最大、最小寬度均可以,加 padding 也可以

.Absolute-Center.is-Responsive {
  width: 60%;
  height: 60%;
  min-width: 400px;
  max-width: 500px;
  padding: 40px;
  overflow: auto;
  margin: auto;
  position: absolute;
  top: 0; left: 0; bottom: 0; right: 0;
}


偏移

只要margin: auto; 在,內(nèi)容塊將垂直居中,top, left, bottom, right 可以設(shè)置偏移。

.Absolute-Center.is-Right {
  width: 50%;
  height: 50%;
  margin: auto;
  overflow: auto;
  position: absolute;
  top: 0; left: auto; bottom: 0; right: 20px;
  text-align: right;
}


溢出

居中內(nèi)容比父容器高時,防止溢出,加 overflow: auto (沒有任何 padding 時,也可以加 max-height: 100%;)。

.Absolute-Center.is-Overflow {
  width: 50%;
  height: 300px;
  max-height: 100%;
  margin: auto;
  overflow: auto;
  position: absolute;
  top: 0; left: 0; bottom: 0; right: 0;
}


調(diào)整尺寸

resize 屬性可以讓尺寸可調(diào)。 設(shè)置 min- /max- 限制尺寸,確定加了 overflow: auto 。

.Absolute-Center.is-Resizable {
  min-width: 20%;
  max-width: 80%;
  min-height: 20%;
  max-height: 80%;
  resize: both;
  overflow: auto;
  margin: auto;
  position: absolute;
  top: 0; left: 0; bottom: 0; right: 0;
}

margin填充

首先我們還是定義父子div:

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

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

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

margin填充

absolute定位

利用position:absolute搭配top,left 50%,再將margin設(shè)為負(fù)值也可以對div進(jìn)行水平垂直居中,首先還是需要定義父子div:
<div class="parent">
  <div class="children"></div>
</div>
然后設(shè)置相應(yīng)的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寬度的一半,最后效果圖:

absolute定位

圖片居中

一般的圖片居中都是和text-align一樣,將圖片包裝在一個div中,將該div的text-align設(shè)為center即可。 


有一種特殊的方式,利用了一個圖片進(jìn)行占位,以讓父容器獲得高寬,從而讓進(jìn)行-50%偏移的圖片能有一個參照容器作百分比計算。優(yōu)點是可以不知道圖片的大小,隨便放張尺寸不超過父容器的圖片上去都能做到居中。另外,兼容性好,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,特別是響應(yīng)式或者移動端的設(shè)計中,更加常見。所以下面介紹一種不需要定寬的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;
}
效果如下所示:

transform居中

首先我們利用float,將需要居中的div的父div也就是children的寬度收縮,然后left:50%,將children的左邊與水平中線對齊。這個時候,還沒有真正居中,我們需要將children-inner左移動-50%,這樣就水平居中了。 

再來說說垂直方向,先將children的top設(shè)為50%,然后其上邊和垂直中線對齊了,同樣,我們需要將children-inner上移動-50%。但是這個50%是計算不出來的,所以我們用到了transform : translate3d(0, -50%, 0); 
這個方法非常好用噢。

flex居中

最后來介紹一下CSS3中的display:flex來實現(xiàn)的水平垂直居中的方法。
<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;
}
效果如下所示:

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





關(guān)閉
程序員人生
主站蜘蛛池模板: 亚洲精品国产福利在线观看 | 国产精品免费久久久久影院小说 | 三人性free欧美高清 | 欧美亚洲桃花综合 | 视频网站在线 | 在线观看视频一区二区 | 亚洲国产一区二区三区精品 | 最新国产在线播放 | 美女无遮挡免费视频网站 | 色午夜视频 | 91久久综合九色综合欧美98 | 国产精品96久久久久久久 | 亚洲 中文 欧美 日韩 在线人 | 偷自拍第一页 | 成人免费视频77777 | 国产精品欧美亚洲韩国日本不卡 | 偷拍区小说区图片区另类呻吟 | 欧美性色网 | 曰本人做爰大片免费观看一 | 一区二区三区精品国产欧美 | 天堂最新版免费观看 | 亚洲精品99久久久久久 | 天堂精品在线 | 欧美成人精品第一区 | 国产亚洲免费观看 | 真实男女xx00动态视频120秒 | 欧美成人午夜视频 | 久久精品全国免费观看国产 | 欧美日韩永久久一区二区三区 | 中文字幕色站 | 欧美黑人巨大xxxx猛交 | 伊人久久大香线蕉综合网站 | 国产精品第一页在线观看 | 国产福利在线观看精品 | 性色按摩过程小说 | 国产欧美一区二区精品久久久 | h视频在线观看视频观看 | 国产亚洲综合视频 | 精品一区二区三区无卡乱码 | 羞羞网站在线看 | 自拍偷拍一区 |