博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
前段元素居中的N种方法
阅读量:3958 次
发布时间:2019-05-24

本文共 2788 字,大约阅读时间需要 9 分钟。

行内元素居中

文本垂直居中
单行文本垂直居中

单行文本的垂直居中是最简单的,设置line-height与盒子高度一样就可以。

这里有一个误区,很多人设置单行文本居中的时候会同时设置heightline-height相同,其实大可不必设置height,只设置line-height就可以,这时候盒子的高度由line-height撑起来,与line-height完全相同。

.center {
// 完全可以不设置高度 // height: 20px; line-height: 20px;}
多行文本垂直居中
  1. vertical-align

    vertical-align可以指定行内元素的垂直对齐方式。

    这个方法需要多增加一个.center元素将需要居中的内容包裹起来。设置父元素的line-height为元素 的高度,居中子元素.centerdisplayinline-block,使其拥有行内元素的特性,因为line-height的继承性,所以设置line-height: 20px;重置居中子元素的line-height,然后设置vertical-align: middle;在行框盒子内垂直居中对齐。

虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
  1. 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属性的可继承性,会导致该元素下得所有子元素全部流方向全部变为横向。而且此时水平方向不能再使用此方法实现居中了。

虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。

水平垂直居中

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;使其在垂直方向上居中对齐。

虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
3.position配合margin

这个方法适用与居中元素宽高已知的情况。设置父元素相对定位,居中元素绝对定位,left、top值都为50%,left、top的值分别相对于父元素的宽高计算,此时居中元素的左上顶点会位于父元素的正中央。然后再设置居中元素的margin-left、margin-top为宽高的负一半,让居中元素在水平方向相对于自身宽度的50%向左偏移,在垂直方向向上偏移相对于自身高度的50%,就可以实现居中效果了。

虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
4.position配合transform

第四种方法是使用position配合transform。这种方法跟上一个方法原理上基本相似,但使用场景增加了宽高不固定的元素。一样的先设置父元素相对定位,居中元素绝对定位,left、top值都为50%。再设置居中元素transform: traslate(-50%, -50%);translate的百分比值是相对于自身去计算的,让居中元素在水平方向相对于自身宽度的50%向左偏移,在垂直方向向上偏移相对于自身高度的50%,就可以实现居中效果了。

虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
5.flex

如果不需要考虑兼容IE9及以前的浏览器,flex布局是最推荐的方式。

设置父元素为flex容器,主轴、交叉轴对齐方式都为居中对。关于flex的相关知识可以参考阮大神的博客,介绍的非常详细。

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

转载地址:http://fiozi.baihongyu.com/

你可能感兴趣的文章
保护U盘批处理文件
查看>>
hibernate 自动导入sql 文件import.sql 国际化编码的问题的解决方案
查看>>
第七颗头骨 & 忘魂花 凤凰
查看>>
李小龙哲学之言
查看>>
潜伏中体现的潜规则
查看>>
[Java] Appfuse 源代码分析
查看>>
[Java] Appfuse 最佳实践
查看>>
[心情] 如果有一天
查看>>
[随笔] 6月近况小记 & 一个站点优化问题
查看>>
[Perl] 关于 Bugzilla 的一些问题与研究
查看>>
[Linux] 常用 linux 系统命令及维护备忘
查看>>
[Linux] 关于 Ext4 HowTo
查看>>
[杂记] 新年物语&关于Mysql引擎性能测试
查看>>
[心得] 近期更新&关于Infobright
查看>>
[杂记] 流量统计 & 短信接口
查看>>
[Java] JRebel + Maven + Jetty 热部署
查看>>
[算法] 从 Memcached 分布式应用看一致性哈希散列函数的选择
查看>>
[中间件] 消息处理利器 ActiveMQ 的介绍 & Stomp 协议的使用
查看>>
[设计] 原型界面设计利器 Balsamiq Mockups 推荐
查看>>
[闲话] 在西方的程序员眼里,东方的程序员是什么样的
查看>>