水平垂直居中

  • 单行的文本、inline 或者 inline-block 元素;
  • 固定宽高的块级盒子;
  • 不固定宽高的块级盒子;

单行的文本、inline 或者 inline-block 元素;

水平居中

.parent {
    text-align: center;
}

垂直居中

方法一:通过设置上下内间距一致达到垂直居中的效果:

.single-line {
    padding-top: 10px;
    padding-bottom: 10px;
}

方法二:通过设置 height 和 line-height 一致达到垂直居中:

.single-line {
    height: 100px;
    line-height: 100px;
}

固定宽高的块级盒子

方法一:absolute + 负 margin
在这里插入图片描述
方法二:absolute + margin auto
在这里插入图片描述
方法三:absolute + calc
在这里插入图片描述

不固定宽高的块级盒子

方法一:absolute + transform
在这里插入图片描述
方法二:line-height + vertical-align
在这里插入图片描述
方法三:writing-mode
在这里插入图片描述
方法四:table-cell
在这里插入图片描述
方法五:flex
在这里插入图片描述
方法六:grid
在这里插入图片描述

在浏览器窗口中居中

基于视口的垂直居中。不要求原生有固定的宽高,但是这种居中是在整个页面窗口内居中,不是基于父元素。

.center{
  margin: 50vh auto;
  transform: translateY(-50%);
}

总结

水平居中的方法

  • 元素为行内元素,设置父元素 text-align:center
  • 如果宽度固定,设置父元素 position 为 relative ,
    – ①子元素设absolute + 负 margin
    – ② absolute + margin auto
  • 宽度不固定
    – ①使用 flex-box 布局,指定justify-content 属性为center;
    – ②或者absolute + transform
    – ③或者display 设置为 tabel-cell
    – ④display:grid

垂直居中的方法

  • 文本垂直居中设置 line-height 为 height 值
  • 将显示方式设置为表格, display:table-cell ,同时设置 vertial-align:middle
  • 使用 flex 布局,设置为 align-item:center
  • 绝对定位中设置 bottom:0,top:0 ,并设置 margin:auto
  • 绝对定位中固定高度时设置 top:50%,margin-top 值为高度一半的负值
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值