我們在編輯一個版面,通常都會用到水平居中和垂直居中來設計,而水平居中很好處理,不外乎就是設定margin:0 auto;或是text-align:center;,就可以輕松解決掉水平居中的問題,但一直以來最麻煩對齊問題,都是“垂直居中”這個討人厭的設定,以下將介紹七種單純利用CSS垂直居中的方式。
七種垂直居中的方法
設定行高(line-height)
設定行高是垂直居中最簡單的方式,適用于“單行”的“行內元素”(inline、inline-block),例如單行的標題,或是已經設為inline-block屬性的div,若將line-height設成和高度一樣的數值,則內容的行內元素就會被垂直居中,因為是行高,所以會在行內元素的上下都加上行高的1/2,所以就垂直居中了!不過由此就可以看出,為什么必須要單行的行內元素,因為如果多行,第二行與第一行的間距會變超大,就不是我們所期望的效果了。CSS示例:
.div0{ width:200px; height:150px; border:1px solid #000; line-height:150px; text-align:center;}.redbox{ display:inline-block; width:30px; height:30px; background:#c00;}
添加偽元素(::before、::after)
剛剛第一種方法,雖然是最簡單的方法(適用于單行標題),不過就是只能單行,所以我們如果要讓多行的元素也可以垂直居中,就必須要使用偽元素的方式。在此之前,先解釋一下CSS里頭vertical-align這個屬性,這個屬性雖然是垂直居中,不過卻是指在元素內的所有元素垂直位置互相居中,并不是相對于外框的高度垂直居中。(下面的CSS會造成這種樣子的垂直居中)
.div0{ width:200px; height:150px; border:1px solid #000; text-align:center;}.redbox{ width:30px; height:30px; background:#c00; display:inline-block; vertical-align:middle;}.greenbox{ width:30px; height:60px; background:#0c0; display:inline-block; vertical-align:middle;}.bluebox{ width:30px; height:40px; background:#00f; display:inline-block; vertical-align:middle;}
因此,如果有一個方塊變成了高度100%,那么其他的方塊就會真正的垂直居中。
.greenbox{ width:30px; height:100%; background:#0c0; display:inline-block; vertical-align:middle;}
但是我們總不能每次要垂直居中,都要添加一個奇怪的div在里頭吧!所以我們就要把腦筋動到“偽元素”身上,利用::before和::after添加div進到杠杠內,讓這個“偽”div的高度100%,就可以輕松地讓其他的div都居中。不過不過不過!div記得要把display設為inline-block,畢竟vertical-align:middle;是針對行內元素,div本身是block,所以必須要做更改!
.div0::before{ content:''; width:0; height:100%; display:inline-block; position:relative; vertical-align:middle; background:#f00;}
calc動態計算
看到這邊或許會有疑問,如果今天我的div必須要是block,我該怎么讓它垂直居中呢?這時候就必須用到CSS特有的calc動態計算的能力,我們只要讓要居中的div的top屬性,與上方的距離是“50%的外框高度+ 50%的div高度”,就可以做到垂直居中,至于為什么不用margin-top,因為margin相對的是水平寬度,必須要用top才會正確。
.div0{ width:200px; height:150px; border:1px solid #000;}.redbox{ width:30px; height:30px; background:#c00; float:left; top:calc(50% - 15px); margin-left:calc(50% - 45px);}.greenbox{ width:30px; height:80px; background:#0c0; float:left; top:calc(50% - 40px);}.bluebox{ width:30px; height:40px; background:#00f; float:left; top:calc(50% - 20px);}
使用表格或假裝表格
或許有些人會發現,在表格這個HTML里面常用的DOM里頭,要實現垂直居中是相當容易的,只需要下一行vertical-align:middle就可以,為什么呢?最主要的原因就在于table的display是table,而td的display是table-cell,所以我們除了直接使用表格之外,也可以將要垂直居中元素的父元素的display改為table-cell,就可以輕松達成,不過修改display有時候也會造成其他樣式屬性的連動影響,需要比較小心使用。
HTML:
<table> <tr> <td> <div>表格垂直居中</div> </td> </tr></table><div class="like-table"> <div>假的表格垂直居中</div></div>
CSS:
.like-table{ display:table-cell;}td,.like-table{ width:150px; height:100px; border:1px solid #000; vertical-align: middle;}td div,.like-table div{ width:100px; height:50px; margin:0 auto; color:#fff; font-size:12px; line-height: 50px; text-align: center; background:#c00;}.like-table div{ background:#069;}
transform
transform是CSS3的新屬性,主要掌管元素的變形、旋轉和位移,利用transform里頭的translateY(改變垂直的位移,如果使用百分比為單位,則是以元素本身的長寬為基準),搭配元素本身的top屬性,就可以做出垂直居中的效果,比較需要注意的地方是,子元素必須要加上position:relative,不然就會沒有效果喔。
.use-transform{ width:200px; height:200px; border:1px solid #000;}.use-transform div{ position: relative; width:100px; height:50px; top:50%; transform:translateY(-50%); background:#095;}
絕對定位
絕對定位就是CSS里頭的position:absolute,利用絕對位置來指定,但垂直居中的做法又和我們正統的絕對位置不太相同,是要將上下左右的數值都設為0,再搭配一個margin:auto,就可以辦到垂直居中,不過要特別注意的是,設定絕對定位的子元素,其父元素的position必須要指定為relative喔!而且絕對定位的元素是會互相覆蓋的,所以如果內容元素較多,可能就會有些問題。
.use-absolute{ position: relative; width:200px; height:150px; border:1px solid #000;}.use-absolute div{ position: absolute; width:100px; height:50px; top:0; right:0; bottom:0; left:0; margin:auto; background:#f60;}
使用Flexbox
使用align-items或align-content的屬性,輕輕松松就可以做到垂直居中的效果。
.use-flexbox{ display:flex; align-items:center; justify-content:center; width:200px; height:150px; border:1px solid #000;}.use-flexbox div{ width:100px; height:50px; background:#099;}
以上就是一些垂直居中的方法,由于垂直居中往往會動用到修改display這個屬性,往往也會在排版上造成一些影響,例如不該用flexbox的地方如果用了flexbox,不該用table的地方用了table,不該用inline-block的地方用了inline-block,后續反而要多寫許多其他的定位樣式來修正,那就有點本末倒置了,因此如何活用這些CSS垂直居中的方法,就要看大家的版面結構而靈活運用亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区三区丝袜| 欧美成人精品一区| 欧美日韩另类视频| 成人精品一区二区三区电影免费| 欧美黄色三级网站| 欧美性视频在线| 欧美日韩国产专区| 动漫精品一区二区| 久久福利视频导航| 久久精品在线视频| 懂色aⅴ精品一区二区三区蜜月| 亚洲欧美在线第一页| www.国产精品一二区| 亚洲午夜未满十八勿入免费观看全集| 久久久久久久久久亚洲| 亚洲黄色av网站| 色诱女教师一区二区三区| 97久久超碰福利国产精品…| 久久久久久国产精品美女| 成人午夜一级二级三级| xxxx欧美18另类的高清| 欧美一级高清免费播放| 欧美电影免费播放| 亚洲男女性事视频| 亚洲国产日韩一区| 麻豆国产va免费精品高清在线| 中文字幕综合一区| 日韩a**中文字幕| 欧美日韩在线观看视频小说| 亚洲奶大毛多的老太婆| 欧美精品久久久久a| 3344国产精品免费看| 午夜精品久久久久久久男人的天堂| 欧美综合在线第二页| 久久久久久亚洲精品中文字幕| 亚洲欧美综合另类中字| 5566日本婷婷色中文字幕97| 亚洲人成啪啪网站| 欧美理论电影在线播放| 国产精品久久久精品| 国产69久久精品成人看| 欧美三级欧美成人高清www| 亚洲欧美在线x视频| 97色在线视频观看| 亚洲直播在线一区| 91久久在线播放| 亚洲欧洲午夜一线一品| 成人信息集中地欧美| 久久精品国产免费观看| 91精品久久久久久久久久久| 国产欧美日韩高清| 欧美成人精品激情在线观看| 欧美日韩成人在线播放| 欧美国产亚洲视频| 国产精品视频地址| 欧美精品在线网站| 亚洲视频专区在线| 国产精品久久久精品| 狠狠色噜噜狠狠狠狠97| 国产成人综合av| 国产精品羞羞答答| 久久人91精品久久久久久不卡| 久久久亚洲精品视频| 成人欧美一区二区三区黑人孕妇| 国内成人精品视频| 久久久久久欧美| 国产精品偷伦免费视频观看的| 国产精品美女www爽爽爽视频| 久久成人精品一区二区三区| 午夜欧美大片免费观看| 国产欧美一区二区| 欧美黑人xxxⅹ高潮交| 欧美成年人网站| 69av视频在线播放| 免费91在线视频| 欧美激情视频免费观看| 中文字幕av一区中文字幕天堂| 日本欧美中文字幕| 美女黄色丝袜一区| 国产91精品最新在线播放| 欧美日韩国产一区二区| 日本精品一区二区三区在线| 国产精品九九久久久久久久| 在线观看视频亚洲| 日韩av第一页| 久久久久久久久久久久久久久久久久av| 7m精品福利视频导航| 视频在线一区二区| 亚洲影院色在线观看免费| 欧美成人合集magnet| 91爱视频在线| 在线播放日韩专区| 亚洲成人动漫在线播放| 久久久精品久久久久| 青草热久免费精品视频| 欧美一区二三区| 日本不卡免费高清视频| 久久网福利资源网站| 欧美视频在线观看免费网址| 日韩欧美aⅴ综合网站发布| 成人福利在线视频| 91精品国产高清自在线看超| 亚洲天堂第二页| 97在线精品国自产拍中文| 伊人激情综合网| 久久久精品在线观看| 亚洲男女自偷自拍图片另类| 国产精品99久久久久久久久久久久| 亚洲第一区中文字幕| 久久免费国产精品1| 91爱爱小视频k| 日韩电影在线观看中文字幕| 综合网日日天干夜夜久久| 色一情一乱一区二区| 九九热精品视频国产| 久久久久亚洲精品成人网小说| 这里只有精品视频在线| 精品久久久久久久久久ntr影视| 国产日韩欧美黄色| 日韩欧美在线国产| 亚洲国产精品人久久电影| 97视频在线免费观看| 不卡中文字幕av| www.亚洲天堂| 国产视频精品va久久久久久| 亚洲桃花岛网站| 亚洲欧美激情四射在线日| 国产美女精品视频免费观看| 国产主播喷水一区二区| 亚洲一区二区自拍| 美女扒开尿口让男人操亚洲视频网站| 国产成人精品国内自产拍免费看| 亚洲人成77777在线观看网| 日韩国产激情在线| 欧美激情喷水视频| 久久久久久美女| 国产aⅴ夜夜欢一区二区三区| 国产精品美女久久久久av超清| 日韩免费av片在线观看| 久久久亚洲影院| 国产精品久久国产精品99gif| 国产三级精品网站| 欧美xxxx18性欧美| 中文字幕欧美日韩| 91色p视频在线| 日韩高清av一区二区三区| 一本大道久久加勒比香蕉| 欧美日韩精品在线观看| 国产小视频91| 亚洲国产97在线精品一区| 日韩亚洲国产中文字幕| 成人亚洲欧美一区二区三区| 欧美久久精品一级黑人c片| 国产精品国产三级国产aⅴ浪潮| 亚洲人成伊人成综合网久久久| 最近2019中文字幕mv免费看| 中文字幕日韩欧美| 国产精品草莓在线免费观看| 精品性高朝久久久久久久| 欧美精品在线观看91| 中文字幕日韩欧美| 欧美色道久久88综合亚洲精品| www.亚洲天堂| 国产精品一区二区av影院萌芽|