校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > css實現元素居中的N種方法

css實現元素居中的N種方法

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

前言

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

行內元素居中

文本垂直居中

單行文本垂直居中

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

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

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

vertical-align可以指定行內元素的垂直對齊方式。

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

<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
不同于行內元素設置利用vertial-align會使當前元素垂直居中對齊,table-cell元素設置vertial-align會讓它的子元素垂直居中對齊,就算子元素是塊級元素也會垂直對齊,所以想要實現塊級元素的垂直居中也可以使用這個方法。

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

行內元素水平居中

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

.center {
       text-align: center;
}

塊級元素水平居中

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

.center {
 margin: 0 auto;
}

塊級元素垂直居中

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

<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>

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

水平垂直居中

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

需要注意的是這個方法只能兼容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
首先實現居中元素在水平方向上的居中,設置居中元素的display值為inline-clock,使其擁有行內元素的特性。給外層的盒元素設置text-align: center;使居中元素在水平方向上居中。
然后再實現在垂直方向上的居中,這個方法需要添加一個輔助元素,設置輔助元素height:100%;使當前行框盒子的高度撐滿父元素,然后設置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
這個方法適用與居中元素寬高已知的情況。設置父元素相對定位,居中元素絕對定位,left、top值都為50%,left、top的值分別相對于父元素的寬高計算,此時居中元素的左上頂點會位于父元素的正中央。然后再設置居中元素的margin-left、margin-top為寬高的負一半,讓居中元素在水平方向相對于自身寬度的50%向左偏移,在垂直方向向上偏移相對于自身高度的50%,就可以實現居中效果了。

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

<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布局是最推薦的方式。
設置父元素為flex容器,主軸、交叉軸對齊方式都為居中對。關于flex的相關知識可以參考阮大神的博客,介紹的非常詳細。

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

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

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

巨人網絡通訊聲明:本文標題《css實現元素居中的N種方法》,本文關鍵詞  css,實現,元素,居,中的,種,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《css實現元素居中的N種方法》相關的同類信息!
  • 本頁收集關于css實現元素居中的N種方法的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    337p粉嫩大胆噜噜噜噜噜91av| 国产999精品久久久久久绿帽| 国产人成一区二区三区影院| 91麻豆精品国产91久久久| 91精彩视频在线| 在线看日韩精品电影| 91久久精品网| 欧美日本乱大交xxxxx| 色哟哟国产精品| 欧美主播一区二区三区| 欧美性生交片4| 欧美肥大bbwbbw高潮| 日韩一二三四区| 26uuu色噜噜精品一区二区| 久久这里只有精品视频网| 久久午夜免费电影| 亚洲欧洲国产专区| 亚洲综合丝袜美腿| 欧美日韩精品欧美日韩精品一| 久久综合丝袜日本网| 婷婷综合在线观看| 亚洲成人精品影院| 美女一区二区三区在线观看| 蜜臀av一级做a爰片久久| 亚洲影视资源网| www.日韩精品| 精品成人一区二区| 偷拍日韩校园综合在线| 欧美系列亚洲系列| 久久久久国产精品人| 日韩制服丝袜先锋影音| 亚洲国产精品久久人人爱| 综合自拍亚洲综合图不卡区| 欧美激情在线一区二区三区| 毛片av中文字幕一区二区| 国产裸体歌舞团一区二区| eeuss鲁片一区二区三区| 精品国产欧美一区二区| 五月婷婷欧美视频| 久久久欧美精品sm网站| 亚洲码国产岛国毛片在线| 日韩精品国产欧美| 成人免费福利片| 91久久国产最好的精华液| 精品国产免费视频| 日韩高清在线电影| 91色在线porny| 精品精品欲导航| 国产精品不卡一区二区三区| 日韩一二三区视频| 高清不卡一区二区| 一区二区三区在线不卡| 欧美日韩国产一区二区三区地区| 久久精品国产**网站演员| 日本高清成人免费播放| 亚洲一二三区在线观看| 在线观看日韩精品| 中文字幕中文字幕一区| 国产三级欧美三级日产三级99 | 久久久久9999亚洲精品| 亚洲欧洲三级电影| 狠狠狠色丁香婷婷综合激情| 欧美视频一区二区在线观看| 中文字幕欧美日韩一区| 蜜桃视频在线一区| 欧美日本一区二区| 一区二区三区四区在线播放| 99国产欧美久久久精品| 久久精品亚洲乱码伦伦中文| 久久av资源网| 欧美videofree性高清杂交| 日韩中文字幕91| 欧美精品一二三四| 丝袜a∨在线一区二区三区不卡| 在线国产亚洲欧美| 亚洲一区在线视频观看| 欧美日韩国产欧美日美国产精品| 国产精品久久久久久久岛一牛影视 | 日韩欧美一级二级三级久久久 | 欧美系列在线观看| 亚洲综合另类小说| 欧美羞羞免费网站| 丝袜美腿亚洲一区二区图片| 欧美久久久久久蜜桃| 免费观看在线综合| 久久精品人人做人人爽97| 粉嫩嫩av羞羞动漫久久久| 国产精品理论片| 91免费小视频| 天堂影院一区二区| 2023国产精品自拍| a美女胸又www黄视频久久| 一卡二卡三卡日韩欧美| 7777精品伊人久久久大香线蕉 | 欧美视频第二页| 久久av中文字幕片| 亚洲婷婷在线视频| 欧美日韩精品久久久| 精品亚洲成a人| 亚洲视频在线一区二区| 91精品午夜视频| 成人中文字幕电影| 午夜欧美2019年伦理| 久久久久国色av免费看影院| 色综合婷婷久久| 日韩电影一二三区| 国产精品久久久久久久久免费丝袜 | 毛片不卡一区二区| 欧美国产日韩亚洲一区| 91亚洲精品一区二区乱码| 天天爽夜夜爽夜夜爽精品视频| 精品少妇一区二区三区免费观看 | 日韩国产精品91| 国产喷白浆一区二区三区| 91猫先生在线| 国产黑丝在线一区二区三区| 亚洲精品国产视频| 亚洲精品在线免费播放| 在线视频国产一区| 国产精品77777| 日韩av一区二区三区四区| 国产精品久久久久久久蜜臀| 日韩一区二区中文字幕| 一本色道a无线码一区v| 麻豆精品视频在线| 亚洲另类在线一区| 国产日韩欧美在线一区| 6080午夜不卡| 色婷婷亚洲精品| 国产精品自拍毛片| 日本在线不卡视频| 亚洲影视在线观看| **性色生活片久久毛片| 精品国产乱码久久久久久夜甘婷婷 | 国产黄人亚洲片| 精品一区二区三区影院在线午夜| 亚洲国产欧美在线| 国产精品传媒在线| 中文字幕乱码一区二区免费| 久久综合五月天婷婷伊人| 欧美一区二区观看视频| 精品视频一区二区三区免费| 91在线观看成人| 99久久国产免费看| av在线不卡观看免费观看| 国产在线精品一区二区夜色| 免费在线看成人av| 日韩国产在线观看| 日本成人在线视频网站| 日韩成人av影视| 日韩av电影免费观看高清完整版| 五月开心婷婷久久| 日韩电影一区二区三区四区| 日产欧产美韩系列久久99| 免费高清视频精品| 国模大尺度一区二区三区| 老司机免费视频一区二区| 久久99国产精品成人| 国产激情91久久精品导航| 国产成人av电影在线观看| 99国产精品久久久| 精品视频123区在线观看| 欧美精品丝袜中出| 精品国一区二区三区| 国产清纯美女被跳蛋高潮一区二区久久w | 日韩写真欧美这视频| 欧美电影免费观看高清完整版在线观看 | 日日摸夜夜添夜夜添国产精品| 五月激情六月综合| 精东粉嫩av免费一区二区三区| 国产一区欧美二区| 99精品视频在线免费观看| 欧美丝袜丝交足nylons图片| 7777精品伊人久久久大香线蕉的| 精品国产免费久久| 亚洲色图在线播放| 日韩国产高清在线| 国产成a人亚洲| 在线观看www91| 欧美成人精精品一区二区频| 国产性色一区二区| 亚洲国产精品视频| 国产成a人亚洲精品| 欧美怡红院视频| 久久品道一品道久久精品| 亚洲欧洲日韩在线| 麻豆国产精品官网| 一本久道久久综合中文字幕| 在线电影院国产精品| 国产欧美1区2区3区| 亚洲国产成人av网| 成人动漫在线一区| 91精品国产综合久久国产大片| 国产婷婷色一区二区三区| 亚洲国产成人91porn| 丁香桃色午夜亚洲一区二区三区| 欧美三级韩国三级日本三斤| 国产亚洲综合在线| 免费在线看成人av| 欧美视频你懂的|