第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

如何優(yōu)雅的實(shí)現(xiàn)垂直居中

標(biāo)簽:
Html/CSS

"44年前我们就把人类送上月球了,但现在我们仍然无法在 CSS 中实现垂直居中。" --Jams Anderson

在网页设计中,每当涉及到居中时,最重要的就是将元素及其父元素居中。听起来很简单,那你有没有考虑到很多的可能性呢(⊙o⊙)?

简单的:已知宽高的元素

如果你同时知道一个元素的宽和高,并且要将元素相对其父元素垂直居中,那么使用绝对定位来实现或许是一种比较不错的办法。


https://img1.sycdn.imooc.com//5d2da4ba0001436806010364.jpg

已知宽高的元素

main{
    position: absolute;
    top: calc(50% - 3em); //向上移动等于父元素高度的50%及自身高度的一半
    left: calc(50% - 9em); //向左移动距离等于父元素宽度的50%及自身宽度的一半
    width: 18em;
    height: 6em;
}

进阶: 未知宽高的元素

但页面中很多元素都是未知宽高的。


https://img1.sycdn.imooc.com//5d2da4bd000133d106030505.jpg

未知宽高的元素

基于绝对定位,进行扩展。

当我们在使用 translate( ) 变形函数计算百分比值时,是以这个元素自身的高度和宽度为基准来进行换算和移动的。因此,只要换用基于百分比的 CSS 变形来对元素进行偏移,就不需要在编译量中将元素的尺寸写死了。

main{    position: absolute;    top: 50%;    left: 50%;    transform: translate( -50%, -50% );
}
不适用绝对定位的情况

当我们不想使用绝对定位时,仍然可以用 translate( ) 来将这个元素以其自身宽高的一半为距离来进行移动。
可以使用 margin 来达到移动的效果。

main{
    width: 18em;
    padding: 13m 1.5em;
    margin: 50vh auto 0; //外边距使用 vh 为单位,因为margin的百分比值是相对于其父元素的宽度作为基准解析,因此此处使用 vh
    transform: translateY( -50% );
}
基于table布局

CSS table 或许是个不错的选择。
因为 table 并不像常规块级元素一样渲染。比如说当元素宽 100% 时,table 只会占据其中实际内容的宽度,而默认的块级元素则会自动的占据父级元素的100%。

<table style="100%">
    <tr>
        <td style="text-align: center; vertaical-align: center">
            我是垂直居中的!        </td>
    </tr></table>

如果考虑到页面语义化,可以这么做

.something-semantic {    display: table;    width: 100%;
}.something-else-semantic {    display: table-cell;    text-align: center;    vertical-align: middle;
}
行内块法

我们甚至可以考虑使用伪元素。
如果我们将伪元素在父元素内占满 100% 的高度,然后我们将伪元素以及希望垂直居中的元素同时设置 vertrcal-align: center。

  • 然后我们就可以得到垂直居中的效果。


    https://img1.sycdn.imooc.com//5d2da4c30001fbc604540454.jpg


    这是一种比较 hack 的方法。

.block {  text-align: center;  white-space: nowrap;
} 
/* 将高度撑到100% */.block:before {  content: '';  display: inline-block;  height: 100%;  vertical-align: middle;  margin-right: -0.25em; /* Adjusts for spacing */}/* 要被垂直居中的元素,可以是任意宽高 */ .centered {  display: inline-block;  vertical-align: middle;  width: 300px;
}
基于 Flexbox 的解决方案

无疑是最佳的解决方案。因为 Flexbox 就是专门针对这类需求设计的

body{    display: flex;    min-height: 100vh;    margin: 0;
}main{    margin: auto;
}

当居中元素内部文本也需要居中时:

main{    display: flex;    align-items: center;    justify-content: center;    width:18em;    height: 10em;
}

参考:
《 CSS 揭秘》
http://css-tricks.com/centering-in-the-unknown
CSS 变形: http://w3.org/TR/css-transforms
CSS 值与单位:http://w3.org/TR/css-values
CSS 伸缩盒模型布局:http://w3.org/TR/css-flexbox



作者:Beginning丶2015
链接:https://www.jianshu.com/p/86e002880769


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺(jué)得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫(xiě)下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消