实现CSS垂直居中的五大方法及优缺点
创始人
2024-07-11 10:31:35
0

你知道如何使CSS垂直居中吗,这里和大家分享一下CSS垂直居中的几种方法以及它们各自的优缺点,相信本文介绍一定会让你有所收获。

CSS垂直居中的几种方法

利用CSS来实现对象的垂直居中有许多不同的方法,比较难的是选择那个正确的方法。我下面说明一下我看到的好的方法和怎么来创建一个好的居中网站。

使用CSS实现垂直居中并不容易。有些方法在一些浏览器中无效。下面我们看一下使对象垂直集中的5种不同方法,以及它们各自的优缺点。

CSS垂直居中方法一:

这个方法把一些div的显示方式设置为表格,因此我们可以使用表格的vertical-alignproperty属性。

  1.  
  2.  
  3.  
  4. Contentgoeshere
 
  •  
  •  
  •  
  • #wrapper{display:table;}  
  • #cell{display:table-cell;vertical-align:middle;}  
  •  
  •  优点:

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

    缺点:

    InternetExplorer(甚至IE8beta)中无效,许多嵌套标签(其实没那么糟糕,另一个专题)

    CSS垂直居中方法二:

    这个方法使用绝对定位的div,把它的top设置为50%,topmargin设置为负的content高度。这意味着对象必须在CSS中指定固定的高度。

    因为有固定高度,或许你想给content指定overflow:auto,这样如果content太多的话,就会出现滚动条,以免content溢出。

    1.  
    2. Contentgoeshere
     
  •  
  • #content{  
  • position:absolute;  
  • top:50%;  
  • height:240px;  
  • margin-top:-120px;/*negativehalfoftheheight*/  
  • }  
  •  
  •  优点:

    适用于所有浏览器

    不需要嵌套标签

    缺点:

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

    CSS垂直居中方法三:

    这种方法,在content元素外插入一个div。设置此divheight:50%;margin-bottom:-contentheight;。
    content清除浮动,并显示在中间。

    1.  
    2.  
    3. Contenthere
     
  •  
  •  
  • #floater{float:left;height:50%;margin-bottom:-120px;}  
  • #content{clear:both;height:240px;position:relative;}  
  •  
  •  优点:

    适用于所有浏览器

    没有足够空间时(例如:窗口缩小)content不会被截断,滚动条出现

    缺点:

    ***我能想到的就是需要额外的空元素了(也没那么糟,又是另外一个话题)

    CSS垂直居中方法四:

    这个方法使用了一个position:absolute,有固定宽度和高度的div。这个div被设置为top:0;bottom:0;。但是因为它有固定高度,其实并不能和上下都间距为0,因此margin:auto;会使它居中。使用margin:auto;使块级元素垂直居中是很简单的。

    1.  
    2. Contenthere
     
  •  
  • #content{  
  • position:absolute;  
  • top:0;  
  • bottom:0;  
  • left:0;  
  •  
  • right:0;  
  • margin:auto;  
  • height:240px;  
  • width:70%;  
  • }  
  •  
  •  优点:简单

    缺点:

    IE(IE8beta)中无效

    无足够空间时,content被截断,但是不会有滚动条出现。#p#

    CSS垂直居中方法五:

    这个方法只能将单行文本置中。只需要简单地把 line-height 设置为那个对象的 height 值就可以使文本居中了。

    1.  
    2.  Content here
     
  •  
  • #content {height:100px; line-height:100px;}  
  • 优点:

    适用于所有浏览器

    无足够空间时不会被截断

    缺点:

    只对文本有效(块级元素无效)

    多行时,断词比较糟糕

    这个方法在小元素上非常有用,例如使按钮文本或者单行文本居中。

    【编辑推荐】

    1. 创建和插入CSS样式表秘笈
    2. IE6.0对padding的解读分析
    3. CSS样式表高效使用八大秘诀
    4. CSS white-space属性及其用法手册
    5. IE6中常见CSS兼容性解决十大技巧

     

    相关内容

    热门资讯

    如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
    如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
    各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
    施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
    Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
    范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
    规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
    20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...