用CSS怎样做垂直居中的效果?教你一个特别的方法
Admin 2021-10-26 群英技术资讯 640 次浏览
对于CSS怎样实现垂直居中的效果,我们之前也了解了很多方法,而不同的实现方法各有其优缺点,本文再给大家分享一个特别的CSS实现垂直居中的方法,感兴趣的朋友就继续往下看吧。
这个就是:伪元素:before
搭配vertical-align:middle
实现元素垂直居中,先来看一下具体的代码实现:
<style type="text/css"> .parent { display: inline-block; width: 300px; height: 300px; font-size: 0; background: #80848f; text-align: center; } .parent:before { display: inline-block; width: 20px; height: 100%; content: ''; background: #ff9900; vertical-align: middle; } .child { display: inline-block; width: 50px; height: 50px; background: #19be6b; vertical-align: middle; } </style>
<div class="parent"> <div class="child">child</div> </div>
上面的代码运行结果是这样的:
相信代码大家已经很熟悉了,但是你真正理解其中的原理吗?下面我们就看一下它是如何怎样一步步实现垂直居中的
分析
首先我们要知道一个关键知识点,那就是:父元素基线(baseline)的位置是可以改变的,它不是固定的,记住这一点很重要
接着,我们精简一下代码,去掉关键部分
<style type="text/css"> .parent { display: inline-block; width: 300px; height: 300px; /* font-size: 0; */ background: #80848f; text-align: center; } .parent:before { display: inline-block; width: 20px; height: 100%; content: ''; background: #ff9900; /* vertical-align: middle; */ } .child { display: inline-block; width: 50px; height: 50px; background: #19be6b; /* vertical-align: middle; */ } </style>
<div class="parent"> <div class="child">child</div> </div>
我们将font-size:0
和vertical-align:middle
注释后,运行结果如下:
从图中不难看出,对于:before
伪元素(以下简称伪元素)来说,加与不加vertical-align:middle,结果都是一样的,在垂直方向它始终会占满父元素;但对于.child元素情况就不同了,它在垂直方向的位置发生了改变,那么这是为什么呢?
其实伪元素在此处的作用就是为了改变(或者叫重新定义)父元素baseline的位置,我们来回顾一下vertical-align:middle
在MDN文档中的定义
middle: 使元素的中部与父元素的基线加上父元素x-height
的一半对齐
那么,对比我们的示例:
font-size
置为0,所以x-height
(小写x字母的高度)的一半也是0,即没有高度这样一下,就相当于伪元素的中点只要与父元素的基线对齐就可以了,因为x-height
是0,所以加与不加无所谓;再加上Css中元素默认是左上方对齐的,对于这个限制,也就是说当伪元素加上vertical-align:middle
后,默认情况下它是不会超出父元素的范围显示的,那么这时伪元素高度已确定:父元素高度的100%,中点也已确定
接下来伪元素就会对父元素说:我垂直方向的中点已经确定了,变是不可能变的,这辈子都不可能变,但我的中点想和你的基线对齐,你自己看着办吧
然后父元素妥协了,将它自身的基线移动到与伪元素中点水平对齐的位置,到此父元素基线的位置也已确定,近似其高度的一半
最后.child元素添加了自己的vertical-align:middle
,按照middle: 使元素的中部与父元素的基线加上父元素x-height
的一半对齐这句定义,.child元素的font-size
由于继承关系也是0,所以它的中点也就自然而然与早已确定的父元素基线对齐,从而实现垂直居中,到此结束
总结
其实该种垂直居中方式的原理主要有以下几个要点:
关于CSS实现垂直居中的方法就介绍到这,上述实例具有一定的借鉴价值,感兴趣的朋友可以参考,希望能对大家有帮助,想要了解更多CSS实现垂直居中的内容,大家可以关注其它的相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
很久没有研究css了,成天用各种框架也基本都不需要自己写,最近要做一个相册页面,碰到的第一个问题就是如何排布。先给出设计稿,然后再说说样式如何写分析一下,有一个容器,容器有padding,每一行的每一个item之间又有margin,首先想到的是这样.container{padding:10px;}.container.item{float:left;width:24%;margin-lef ...
在css中,可用border属性做直角梯形,语法为“元素{border:0px solid transparent;border-top:梯形高度 solid 颜色;border-left:梯形长度 solid transparent}”。
CSS属性选择器用哪个合适,基本用法是怎样?有些朋友可能对属性选择器不陌生,但面对各种类型的属性选择器却不知道用哪个比较好。为了帮助大家解决困惑,小编在此特地整理了相关资料,一起来看看吧!
importReactfrom'react'importPropTypesfrom'prop-types'importCXfrom'classnames'import_from'lodash'import'./index.less'functionRadioButton(props){const{style,title,isChec
在平常的样式排版中,我们经常遇到将某个模块隐藏的场景,通过css隐藏元素的方法有很多种,它们看起来实现的效果是一致的,但实际上每一种方法都有一丝轻微的不同,这些不同决定了在一些特定场合下使用哪一种方法。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008