如何保持浮层水平垂直居中 ?

本文阅读 2 分钟
首页 前端笔记 正文

一、水平居中

(1)行内元素解决方案

只需要把行内元素包裹在一个属性 display 为 block 的父层元素中,并且把父层元素添加如下属性即可。

  1. .parent {
  2. text-align: center;
  3. }

(2)块状元素解决方案

  1. .item {
  2. /* 这里可以设置顶端外边距 */
  3. margin: 10px auto;
  4. }

(3)多个块状元素解决方案将元素的 display 属性设置为 inline-block,并且把父元素的 text-align 属性设置为 center 即可:

  1. .parent {
  2. text-align:center;
  3. }

(4)多个块状元素解决方案

使用 flexbox 布局,只需要把待处理的块状元素的父元素添加属性 display: flex 及 justify-content: center 即可。

  1. .parent {
  2. display: flex;
  3. justify-content: center;
  4. }

二、垂直居中

(1)单行的行内元素解决方案

  1. .parent {
  2. background: #222;
  3. height: 200px;
  4. }
  5. /* 以下代码中,将 a 元素的 height 和 line-height 设置的和父元素一样高度即可实现垂直居中 */
  6. a {
  7. height: 200px;
  8. line-height:200px;
  9. color: #FFF;
  10. }

(2)多行的行内元素解决方案组合

使用 display: table-cell 和 vertical-align: middle 属性来定义需要居中的元素的父容器元素生成效果,如下:

  1. .parent {
  2. background: #222;
  3. width: 300px;
  4. height: 300px;
  5. /* 以下属性垂直居中 */
  6. display: table-cell;
  7. vertical-align: middle;
  8. }

(3)已知高度的块状元素解决方案

  1. .item{
  2. position: absolute;
  3. top: 50%;
  4. margin-top: -50px; /* margin-top值为自身高度的一半 */
  5. padding:0;
  6. }

三、水平垂直居中

(1)已知高度和宽度的元素解决方案 1

这是一种不常见的居中方法,可自适应,比方案 2 更智能,如下:

  1. .item{
  2. position: absolute;
  3. margin:auto;
  4. left:0;
  5. top:0;
  6. right:0;
  7. bottom:0;
  8. }

(2)已知高度和宽度的元素解决方案 2

  1. .item{
  2. position: absolute;
  3. top: 50%;
  4. left: 50%;
  5. margin-top: -75px; /* 设置margin-left / margin-top 为自身高度的一半 */
  6. margin-left: -75px;
  7. }

(3)未知高度和宽度元素解决方案

  1. .item{
  2. position: absolute;
  3. top: 50%;
  4. left: 50%;
  5. transform: translate(-50%, -50%); /* 使用 css3 的 transform 来实现 */
  6. }

(4)使用 flex 布局实现

  1. .parent{
  2. display: flex;
  3. justify-content: center;
  4. align-items: center;
  5. /* 注意这里需要设置高度来查看垂直居中效果 */
  6. background: #AAA;
  7. height: 300px;
  8. }
解压密码: detechn或detechn.com

免责声明

本站所有资源出自互联网收集整理,本站不参与制作,如果侵犯了您的合法权益,请联系本站我们会及时删除。

本站发布资源来源于互联网,可能存在水印或者引流等信息,请用户自行鉴别,做一个有主见和判断力的用户。

本站资源仅供研究、学习交流之用,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担。

清除浮动,什么时候需要清除浮动,清除浮动都有哪些方法 ?
« 上一篇 03-12
position 、float 和 display 的取值和各自的意思和用法
下一篇 » 03-12

发表评论