顽石系列:CSS实现垂直居中的五种方法

顽石系列:CSS实现垂直居中的五种方法

在开发过程中,我们可能沿用或者试探性地去使用某种方法实现元素居中,但是对各种居中方法的以及使用场景很不清晰。参考的内容链接大概如下:

  • 行内元素:https://blog.csdn.net/bwf_erg/article/details/69844527
  • MDN文档:https://developer.mozilla.org/zh-CN/docs/Web/CSS/vertical-align
  • 六种方法:https://www.jianshu.com/p/086364d3d5e2
  • 五种方法:https://www.qianduan.net/css-to-achieve-the-vertical-center-of-the-five-kinds-of-methods/

方法一:Vertical-Align法

  我们使用 vertical-align:middle 来实现元素垂直居中

  

  CSS 的属性 vertical-align 用来指定行内元素(inline)或表格单元格(table-cell)元素的垂直对齐方式

行内元素的记忆技巧:

  字体大小要加粗,

  组合图像输入框,

  锚准斜体的菜单,

  强调换行上下标

  我们可以把div 的显示方式设置为表格,从而使用表格的 vertical-align middle 属性

    <style>
        #wrapper{
            width: 200px;
            height: 200px;
            background-color: aqua;
            display: table;
        }
        #content{
            display: table-cell;
            vertical-align: middle;
        }
    </style>

    <div id="wrapper">
        <div id="content">
            Content is Here!
        </div>
    </div>

分析

优点:

  • content 可以动态改变高度(不需在 CSS 中定义)。当 wrapper 里没有足够空间时, content 不会被截断

缺点:

  • Internet Explorer(甚至 IE8 beta)中无效,许多嵌套标签(其实没那么糟糕,另一个专题)

方法二:绝对定位+负边距法

  这个方法使用绝对定位的 div,把它的 top 设置为 50%margin-top 设置为负的 content 高度。这意味着对象必须在 CSS 中指定固定的高度。因为有固定高度,也许你得给 content 指定 overflow:auto,这样如果 content 太多的话,就会出现滚动条,以免content 溢出。

<div class="content"> Content goes here</div>  

#content {
    position: absolute;
    top: 50%;
    height: 240px;
    margin-top: -120px; /* negative half of the height */
}

分析

优点:

  • 适用于所有浏览器
  • 不需要嵌套标签

缺点:

  • 没有足够空间时,content 会消失(类似div 在 body 内,当用户缩小浏览器窗口,滚动条不出现的情况)

方法三:浮动元素法

  这个方法的原理是利用一个空的浮动元素来控制主要内容在容器中的位置

  

  比如我们的目标是让红色DIV位于绿色父级元素的中间,我们要让一个浮动元素占据黄色的位置,然后红色元素清除浮动,自然而然到达居中位置。

        #parent {
            padding: 5% 0;
            background-color: green;
        }

        #floater {
            float: left;
            height: 50%;
            width: 100%;
            margin-bottom: -50px;
            background: yellow;
        }

        #child {
            clear: both;
            height: 100px;
            background: red;
        }

        <div id="parent">
            <div id="floater"></div>
            <div id="child">Content here</div>
        </div>

方法四:FLEX定位法

  CSS属性flex规定了弹性元素如何伸长或缩短以适应flex容器中的可用空间

  效果是这样的:

  

        #wrapper{
            display: flex;
            height: 100px;
            background: green;
        }
        #content{
            margin: auto;
            background-color: red;
        }

    <div id="wrapper">
        <div id="content">
            Content is Here!
        </div>
    </div>

 还有一种垂直居中的实现方式 ,针对移动端页面布局的,很好用

#parent{
  display:flex ;
  align-items:center; 垂直居中
  justify-content:center ; //水平居中
}

方法五:Line-Height方法

  这个方法适用于单行文字的垂直居中,只需要将包含文字元素的容器行高设置为大于字体大小并且等于元素的高度。默认情况下,文字上下部分会留有相同的空间,因而实现了文字的垂直居中。

<div id="parent">
    <div id="child">Text here</div>
</div>

#child {
    line-height: 200px;
}

  这种方法只适用于单行文字的垂直居中,如果需要多行文字居中,需要选择其他方法

原文地址:https://www.cnblogs.com/MrSaver/p/9893170.html

时间: 2024-12-04 15:25:08

顽石系列:CSS实现垂直居中的五种方法的相关文章

CSS总结div中的内容垂直居中的五种方法

文章目录 一.行高(line-height)法 二.内边距(padding)法 三.模拟表格法 四.CSS3的transform来实现 五:css3的box方法实现水平垂直居中 六:flex布局(2018/04/17补充) 一.行高(line-height)法 如果要垂直居中的只有一行或几个文字,那它的制作最为简单,只要让文字的行高和容器的高度相同即可,比如: p { height:30px; line-height:30px; width:100px; overflow:hidden; } 这

CSS实现垂直居中的5种方法

利用 CSS 来实现对象的垂直居中有许多不同的方法,比较难的是选择那个正确的方法.我下面说明一下我看到的好的方法和怎么来创建一个好的居中网站. 使用 CSS 实现垂直居中并不容易.有些方法在一些浏览器中无效.下面我们看一下使对象垂直集中的5种不同方法,以及它们各自的优缺点.(可以看看测试页面,有简短解释.) 方法一: 这个方法把一些 div 的显示方式设置为表格,因此我们可以使用表格的 vertical-align property 属性. <div id="wrapper"&g

CSS元素垂直居中的几种方法

在网页响应式布局中,实现水平居中很简单.可是,垂直居中方面,元素的宽度和高度是不可控的,所以很多办法并不适用. 总结了下平时用到的垂直居中的几种办法: demo中HTML代码: <div class="center"> <span></span> </div> 一:使用table-cell; CSS代码: .table{ display: table; width: 100%; height: 100%; } .center{ displ

[转]-CSS 元素垂直居中的6种方法

原文地址:http://blog.zhourunsheng.com/2012/03/css-%E5%85%83%E7%B4%A0%E5%9E%82%E7%9B%B4%E5%B1%85%E4%B8%AD%E7%9A%84-6%E7%A7%8D%E6%96%B9%E6%B3%95/ 利用CSS进行元素的水平居中,比较简单,行级元素设置其父元素的text-align center,块级元素设置其本身的left 和 right margins为auto即可.本文收集了六种利用css进行元素的垂直居中的方

CSS 元素垂直居中的 6种方法

利用CSS进行元素的水平居中,比较简单,行级元素设置其父元素的text-align center,块级元素设置其本身的left 和 right margins为auto即可.本文收集了六种利用css进行元素的垂直居中的方法,每一种适用于不同的情况,在实际的使用过程中选择某一种方法即可. Line-Height Method 试用:单行文本垂直居中,demo 代码: html 1 2 3 <div id="parent"> <div id="child&quo

CSS 元素垂直居中的 6种方法(转)

转自:http://blog.zhourunsheng.com/2012/03/css-%E5%85%83%E7%B4%A0%E5%9E%82%E7%9B%B4%E5%B1%85%E4%B8%AD%E7%9A%84-6%E7%A7%8D%E6%96%B9%E6%B3%95/ 利用CSS进行元素的水平居中,比较简单,行级元素设置其父元素的text-align center,块级元素设置其本身的left 和 right margins为auto即可.本文收集了六种利用css进行元素的垂直居中的方法,

(转)CSS 元素垂直居中的 6种方法

利用CSS进行元素的水平居中,比较简单,行级元素设置其父元素的text-align center,块级元素设置其本身的left 和 right margins为auto即可.本文收集了六种利用css进行元素的垂直居中的方法,每一种适用于不同的情况,在实际的使用过程中选择某一种方法即可. Line-Height Method 试用:单行文本垂直居中,demo 代码: html 1 2 3 <div id="parent"> <div id="child&quo

纯CSS实现垂直居中的几种方法

垂直居中是布局中十分常见的效果之一,为实现良好的兼容性,PC端实现垂直居中的方法一般是通过绝对定位,table-cell,负边距等方法.有了css3,针对移动端的垂直居中就更加多样化. 方法1:table-cell html结构: 1 2 3 <div class="box box1">         <span>垂直居中</span> </div> css: 1 2 3 4 5 .box1{     display: table-ce

CSS水平垂直居中的几种方法

直接进入主题! 一.脱离文档流元素的居中 方法一:margin:auto法 CSS代码: div{ width: 400px; height: 400px; position: relative; border: 1px solid #465468; } img{ position: absolute; margin: auto; top: 0; left: 0; right: 0; bottom: 0; } HTML代码: <div> <img src="mm.jpg&quo