欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > css實現(xiàn)元素居中的N種方法

css實現(xiàn)元素居中的N種方法

熱門標簽:地圖標注位置怎么弄圖 電銷外呼系統(tǒng)是違法的嗎 威力最大的電銷機器人 漯河外呼調(diào)研線路 電話機器人鑰匙扣 電銷專用外呼線路 旅游地圖標注線路 廣西房產(chǎn)智能外呼系統(tǒng)推薦 400電話唐山辦理

前言

剛參加工作時被面試官一連串居中問題虐的體無完膚得場景歷歷在目。“你是如何實現(xiàn)文本的居中的”“如果是多行文本呢”“塊級元素的水平居中如何實現(xiàn)”“塊級元素的垂直居中如何實現(xiàn)”。。。問到后面腦子里一團漿糊,本來知道的也不知道該如何回答了。居中是日常工作中不可避免要遇到的場景,面試中也是高頻出現(xiàn)。這次的文章就圍繞這些問題展開,希望能夠幫助有和我當年一樣疑惑的同學,在今后的工作和面試中再面對居中問題的時候可以游刃有余。

行內(nèi)元素居中

文本垂直居中

單行文本垂直居中

單行文本的垂直居中是最簡單的,設(shè)置line-height與盒子高度一樣就可以。
這里有一個誤區(qū),很多人設(shè)置單行文本居中的時候會同時設(shè)置height與line-height相同,其實大可不必設(shè)置height,只設(shè)置line-height就可以,這時候盒子的高度由line-height撐起來,與line-height完全相同。

.center {
  // 完全可以不設(shè)置高度
  // height: 20px;
  line-height: 20px;
}

多行文本垂直居中
1.vertical-align

vertical-align可以指定行內(nèi)元素的垂直對齊方式。

這個方法需要多增加一個.center元素將需要居中的內(nèi)容包裹起來。設(shè)置父元素的line-height為元素的高度,居中子元素.center的display為inline-block,使其擁有行內(nèi)元素的特性,因為line-height的繼承性,所以設(shè)置line-height: 20px;重置居中子元素的line-height,然后設(shè)置vertical-align: middle;在行框盒子內(nèi)垂直居中對齊。

<div class="box">
 <div class="center">
  雖然你們是扮演路人甲乙丙丁,但是一樣是有生命、有靈魂的。
 </div>
</div>
<style>
.box {
 background-color: orange;
 line-height: 200px;
 width: 300px;
}
.center {
 background-color: green;
 line-height: 20px;
 display: inline-block;
 vertical-align: middle;
}
</style>

2.table-cell
不同于行內(nèi)元素設(shè)置利用vertial-align會使當前元素垂直居中對齊,table-cell元素設(shè)置vertial-align會讓它的子元素垂直居中對齊,就算子元素是塊級元素也會垂直對齊,所以想要實現(xiàn)塊級元素的垂直居中也可以使用這個方法。

.box {
       height: 200px;
       display: table-cell;
       vertical-align: middle;
}

行內(nèi)元素水平居中

text-align控制子行內(nèi)元素的水平對齊方式,這個非常簡單直接設(shè)置text-align:center就可以。

.center {
       text-align: center;
}

塊級元素水平居中

margin的值為auto可以占據(jù)對應方向的所有剩余空間,如果設(shè)置水平方向上兩個方向的margin值都為auto,兩個方向就會平分剩余空間,從而實現(xiàn)居中。
那么為什么我們從來沒有使用這個方法來實現(xiàn)垂直方向的居中呢?因為auto值起作用有一個前置條件,就是在對應的方向上如果不設(shè)置具體的長度,會自動鋪滿。很顯然width是可以鋪滿父元素的,而height不可以。

.center {
 margin: 0 auto;
}

塊級元素垂直居中

那可不可以利用margin:auto;實現(xiàn)垂直方向的居中呢?當然可以,可以通過修改writing-mode改變塊的流動,使塊橫向流動,此時height方向就會默認平鋪撐滿,設(shè)置margin:auto;就可以實現(xiàn)垂直方向的居中。但是這個方法有副作用,因為writing-mode屬性的可繼承性,會導致該元素下得所有子元素全部流方向全部變?yōu)闄M向。而且此時水平方向不能再使用此方法實現(xiàn)居中了。

<div class="box">
    <div class="center"> 
        雖然你們是扮演路人甲乙丙丁,但是一樣是有生命、有靈魂的。
    </div>
</div>
<style>
.box {
 background-color: orange;
 height: 200px;
 writing-mode: vertical-lr;;
}
.center {
 background-color: green;
 height: 50px;
 margin: auto 0;
}
</style>

那有沒有可能使用這個特性實現(xiàn)垂直與水平方向都居中呢?也是可以得,我們繼續(xù)往下看

水平垂直居中

1.position(居中元素寬高固定)
設(shè)置父元素絕對定位,居中元素相對定位,top、right、bottom、left的值都為0,此時如果不設(shè)置具體的寬高,居中元素就會在水平和垂直兩個方向都鋪滿父元素。此時再給它設(shè)置具體寬高配合margin:auto;就可以實現(xiàn)絕對居中了。

需要注意的是這個方法只能兼容IE8及以上瀏覽器,如果項目要兼容IE7可以使用下面這種方法

.box {
 position: relative;
}
.center {
 position:absolute;
 width: 200px;
 height: 200px;
 top:0;
 bottom:0;
 left:0;
 right:0;
 margin: auto;
}

2.vertacal-align
首先實現(xiàn)居中元素在水平方向上的居中,設(shè)置居中元素的display值為inline-clock,使其擁有行內(nèi)元素的特性。給外層的盒元素設(shè)置text-align: center;使居中元素在水平方向上居中。
然后再實現(xiàn)在垂直方向上的居中,這個方法需要添加一個輔助元素,設(shè)置輔助元素height:100%;使當前行框盒子的高度撐滿父元素,然后設(shè)置vertical-align: middle;使其在垂直方向上居中對齊。

<div class="box">
    <div class="assist"></div>
    <div class="center"> 
        雖然你們是扮演路人甲乙丙丁,但是一樣是有生命、有靈魂的。
    </div>
</div>
<style>
.box {
    background-color: orange;
    height: 200px;
    width: 500px;
    text-align: center;
}
.center {
    background-color: green;
    width: 150px;
    display: inline-block;
    vertical-align: middle;
}
.assist {
    display: inline-block;
    height: 100%;
    vertical-align: middle;
}
</style>

3.position配合margin
這個方法適用與居中元素寬高已知的情況。設(shè)置父元素相對定位,居中元素絕對定位,left、top值都為50%,left、top的值分別相對于父元素的寬高計算,此時居中元素的左上頂點會位于父元素的正中央。然后再設(shè)置居中元素的margin-left、margin-top為寬高的負一半,讓居中元素在水平方向相對于自身寬度的50%向左偏移,在垂直方向向上偏移相對于自身高度的50%,就可以實現(xiàn)居中效果了。

<div class="box">
    <div class="center"> 
        雖然你們是扮演路人甲乙丙丁,但是一樣是有生命、有靈魂的。
    </div>
</div>
<style>
.box {
    background-color: orange;
    height: 200px;
    width: 500px;
    position: relative;
}
.center {
    background-color: green;
    width: 150px;
    height: 50px;
    position:absolute;
    top:50%;
    left:50%;
    margin-left: -75px;
    margin-top: -25px;
}
</style>

4.position配合transform
第四種方法是使用position配合transform。這種方法跟上一個方法原理上基本相似,但使用場景增加了寬高不固定的元素。一樣的先設(shè)置父元素相對定位,居中元素絕對定位,left、top值都為50%。再設(shè)置居中元素transform: traslate(-50%, -50%);,translate的百分比值是相對于自身去計算的,讓居中元素在水平方向相對于自身寬度的50%向左偏移,在垂直方向向上偏移相對于自身高度的50%,就可以實現(xiàn)居中效果了。

<div class="box">
    <div class="center"> 
        雖然你們是扮演路人甲乙丙丁,但是一樣是有生命、有靈魂的。
    </div>
</div>
<style>
.box {
    background-color: orange;
    height: 200px;
    width: 500px;
    position: relative;
}
.center {
    background-color: green;
    width: 150px;
    position:absolute;
    top:50%;
    left:50%;
    transform: traslate(-50%, -50%);
}
</style>

5.flex
如果不需要考慮兼容IE9及以前的瀏覽器,flex布局是最推薦的方式。
設(shè)置父元素為flex容器,主軸、交叉軸對齊方式都為居中對。關(guān)于flex的相關(guān)知識可以參考阮大神的博客,介紹的非常詳細。

.box {
    display: flex;
    align-items: center;
    justify-content: center;
}

到此這篇關(guān)于css實現(xiàn)元素居中的N種方法的文章就介紹到這了,更多相關(guān)css 元素居中內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家! 

標簽:欽州 試駕邀約 無錫 綏化 湖北 湘西 銅陵 焦作

巨人網(wǎng)絡(luò)通訊聲明:本文標題《css實現(xiàn)元素居中的N種方法》,本文關(guān)鍵詞  css,實現(xiàn),元素,居,中的,種,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《css實現(xiàn)元素居中的N種方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于css實現(xiàn)元素居中的N種方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    国产高清视频免费在线观看| 日韩亚洲国产中文字幕欧美| 亚洲国产精品v| 国产一区二区网址| 少妇av片在线观看| 久久综合精品国产一区二区三区| 日本女优在线视频一区二区| 久草视频福利在线| 欧美一级精品大片| 美日韩一级片在线观看| 中文字幕国产综合| 久久综合九色综合97婷婷| 精品在线免费视频| 国产一二三四区在线| 26uuu亚洲综合色| 久久国产精品一区二区| 欧美电影免费观看高清完整版| 欧洲精品中文字幕| 亚洲欧美区自拍先锋| 99久久综合色| 欧美性猛片xxxx免费看久爱| 亚洲国产aⅴ天堂久久| 欧美日韩一区二区三区四区五区六区| 91精品国产欧美一区二区成人| 天堂成人国产精品一区| 丰满少妇在线观看资源站| 精品日韩一区二区三区免费视频| 美脚の诱脚舐め脚责91| 极品蜜桃臀肥臀-x88av| 日本一区二区综合亚洲| 成人av网址在线观看| 欧美性受xxxx| 三级精品在线观看| 午夜时刻免费入口| 国产精品夫妻自拍| 亚洲区 欧美区| 日韩一级黄色片| 国内精品国产成人| 色综合久久久久久久久久久| 亚洲自拍偷拍网站| 一出一进一爽一粗一大视频| 久久精品无码一区二区三区| www.66久久| 欧美精品日韩一区| 久久成人久久爱| 国产88在线观看入口| 亚洲大片精品永久免费| 亚洲欧洲久久久| 综合欧美一区二区三区| 亚洲av无码国产精品麻豆天美| 欧美日韩成人激情| 伦理电影国产精品| 三级影片在线观看| 亚洲永久免费视频| 青娱乐国产视频| 亚洲精品一卡二卡| 免费观看av网站| 自拍偷拍国产精品| 久久亚洲AV成人无码国产野外| 国产欧美一区视频| av不卡中文字幕| 欧美韩国日本综合| 国产精品嫩草69影院| 久久综合国产精品| 国产伦理在线观看| 国产视频在线观看一区二区三区| 欧美xxxx黑人| 久久久久久久久97黄色工厂| 亚洲精品乱码久久久久久9色| 久久男人中文字幕资源站| 91在线小视频| 久久精品视频免费| 久草免费资源站| 欧美国产精品一区二区| 午夜剧场免费看| 国产精品高潮呻吟久久| 久久久久久亚洲中文字幕无码| 亚洲日穴在线视频| 无码少妇精品一区二区免费动态| 夜色激情一区二区| 少妇被躁爽到高潮无码文| 奇米在线7777在线精品| 色就色 综合激情| 国产在线精品一区二区不卡了| 欧美日本在线看| 丁香六月综合激情| 精品国产一二三| 国产乱淫av片| 亚洲欧洲精品天堂一级| 久久精品国产亚洲av久| 午夜欧美在线一二页| 18岁成人毛片| 国产一区二区三区av电影| 欧美一区二区大片| 日本中文字幕有码| 国产精品第一页第二页第三页| 在线视频第一页| 人人精品人人爱| 欧美剧情片在线观看| av午夜精品一区二区三区| 国产欧美日韩精品a在线观看| 国产吞精囗交久久久| 亚洲制服丝袜一区| 色伊人久久综合中文字幕| 国产精品69毛片高清亚洲| 欧美成人在线直播| 中国极品少妇videossexhd| 一区二区三区久久久| 黄色片在线观看网站| 国产91精品在线观看| 国产日韩欧美精品在线| 蜜桃传媒一区二区亚洲| 美女免费视频一区| 555夜色666亚洲国产免| 91麻豆国产精品久久| 中文字幕欧美一| 卡通动漫亚洲综合| 成人在线视频首页| 一区精品在线播放| www.av免费| 成人黄色片在线观看| 中文字幕一区二区在线播放| www欧美com| av资源站一区| 一区二区三区在线观看欧美| 日本福利一区二区| 91日韩一区二区三区| 一区二区久久久久| 欧美日韩在线综合| 蜜桃视频无码区在线观看| 亚洲国产视频网站| 制服丝袜国产精品| 中文字幕一区二区三区人妻不卡| 日本在线播放一区二区三区| 欧美tickling网站挠脚心| 国产av自拍一区| 韩国av一区二区| 国产欧美va欧美不卡在线| 四虎884aa成人精品| 成人精品视频一区二区三区| 18涩涩午夜精品.www| 色欧美片视频在线观看 | 丝袜亚洲另类丝袜在线| 91精品中文字幕一区二区三区 | 亚洲蜜臀av乱码久久精品| 色偷偷成人一区二区三区91| 91美女在线观看| 日日骚欧美日韩| 欧美精品一区二区三区蜜桃| 亚洲第一视频区| 成人午夜短视频| 亚洲综合在线五月| 日韩欧美综合在线| 任你操精品视频| 99久久婷婷国产综合精品电影 | 性生交大片免费看l| 五月天久久比比资源色| 精品久久五月天| 少妇视频一区二区| 下面一进一出好爽视频| 天堂一区二区在线| 久久精品亚洲乱码伦伦中文| 色狠狠av一区二区三区| www.男人天堂| 国产精品资源在线| 亚洲黄色在线视频| 日韩欧美精品三级| 精品自拍偷拍视频| 妖精视频一区二区| 国产一区二区三区免费播放| 亚洲免费在线观看视频| 欧美一区二区三区免费在线看 | 有码一区二区三区| 欧美一级生活片| 一区二区三区影视| www.黄色网| 国产一区二区三区在线观看免费视频| 中文字幕一区二区日韩精品绯色 | 成人午夜看片网址| 午夜精品一区二区三区电影天堂 | 欧美日韩精品久久久| xxxxx在线观看| www.综合网.com| 日本不卡视频在线观看| 国产欧美日韩麻豆91| 51久久夜色精品国产麻豆| 美国精品一区二区| 国产高潮视频在线观看| 国产成人激情av| 日韩专区欧美专区| 国产精品另类一区| 欧美刺激午夜性久久久久久久| 色婷婷久久久久swag精品 | 一区二区三区自拍| 久久色在线视频| 欧美日韩高清不卡| 午夜精品一区二区三级视频| 国产精品久久久免费观看| 成年人国产精品| 久久狠狠亚洲综合|