找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1580|回复: 1

[分享] CSS设置垂直居中详细分析

[复制链接]
发表于 2013-3-4 08:50:40 | 显示全部楼层 |阅读模式 来自 中国–北京–北京
一直以来,使用CSS设置内容在容器中的垂直居中,并同时做到多浏览器兼容都是一个困扰前端开发人员的麻烦问题。网上流传的方法中大多兼容性差,或者代码结构复杂,而且通用性差。

内容的垂直居中问题一般会分以下几种情况:
1.固定高度,单行文本垂直居中
2.固定高度,多行文本垂直居中
3.有最小高度,当内容多时高度自适应
以上三种情况,用table设置td的vertical-align可以完全解决,但是设置垂直居中使用table,会造成代码冗余,因此适当用line-height或者position等方法也未尝不可。但是大多情况下,局限性太大,兼容性也有问题。
来看一下下面的的这个设计图。



要如何实现,恐怕就犯难了,以上的方法可能都无法很好的处理。
该图中的需求有几个,每行信息在说明文字少的时候有默认的最小高度,每列要求各个数据水平方向垂直居中对齐。每个位置的数据都有可能是单行或多行,数据完全显示,每行之间有间距。
对以上要求显而易见使用table会很方便,但是如果每行之间的间距的如何处理,可能就会有问题了,每行一个table呢?还是整个数据都是一个table,每列是一个tr。的方法会产生很多冗余的标签,页面结构会很复杂。方法的话,每行之间的间距不能用table处理,兼容性问题无法解决。
如何解决?
对inline-block有过仔细了解的人就可能会知道,inline-block具有inline的一些属性,这里要使用的就是他对 vertical-align: middle的支持,对这个了解的人就很少了。
那么如何实现?
对图中的结构,HTML代码如下:
  • <div class="list">
  •       <p style="width:80px;">10% off Economy class</p>
  •       <p style="width:160px;">Can be modified</p>
  •       <p style="width:160px;">Can be refunded.</p>
  •       <p style="width:160px;">Can be endorsed</p>
  •    </div>
  •    <div class="list">
  •       <p style="width:80px;">first class</p>
  •        <p style="width:160px;">Free change permitted within same class if
  • available at least 4 days prior to departure.</p>
  •       <p style="width:160px;">20% of fare charged (minimum CNY50 charge). </p>
  •       <p style="width:160px;">Can not be endorsed</p>
  •    </div>

复制代码

上面是理想状态下代码结构,当然你可以为了语义,修改标签。
那么CSS要如何写呢?下面就是我所给出的方法,为了说明问题,请注意粗体部分代码:
  • body{color:black;background-color:white;padding:50px;}
  •    * {font-size: 12px;font-family:tahoma;margin: 0;padding:0;border-width: 0;}
  •    .list{width:650px;margin-bottom: 1px;padding: 10px;border: solid 1px #00a0da;
  • background-color:#e5f3f8; }
  •    .list p {vertical-align: middle;display: -moz-inline-stack;display: inline-block; zoom:1;*dis

复制代码

vertical-align: middle;display: -moz-inline-stack;display: inline-block; zoom:1;是重点。

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

 楼主| 发表于 2013-3-4 08:57:29 | 显示全部楼层 来自 中国–北京–北京
[2.]inline-block元素之间的垂直居中总会以元素中最高的那个元素为基准做垂直居中对齐。这个问题后面讲。
[1.]的解决方法,让代码紧凑点就可以了,修改HTML代码后:
<div class=”list”><p style=”width:80px;”>10% off Economy class</p><p style=”width:160px;”>Can be modified</p><p style=”width:160px;”>Can be refunded.</p><p style=”width:160px;”>Can be endorsed</p> </div>
<div class=”list”><p style=”width:80px;”>first class</p><p style=”width:160px;”>Free change permitted within same class if available at least 4 days prior to departure.</p><p style=”width:160px;”>20% of fare charged (minimum CNY50 charge). </p>
<p style=”width:160px;”>Can not be endorsed</p></div>
复制代码
[2.]的情况我们注意到了,我们会利用这一点设置列元素的默认高度。既然inline-block元素之间的垂直居中总会以元素中最高的那个元素为基准做垂直居中对齐,那么默认高度我们可以选取合适的元素去设置高度比如每行最后一个元素,内容固定,给他设置高度就行了,这样默认高度就ok了。当其他位置因为内容过多,造成高度变高,那么基准会变换位最高的元素,仍然实现每行的垂直居中。如果其他位置因为内容过少,基准以最后一个元素的为准,满足默认高度的情况需要。
但是如果以上的最后一个元素也会有内容多少变化的问题,那么这时候你可以创建一个空标签给个高度让它做每行元素的对齐基线。
例如:
<div class=”list”><b>hi</b><p style=”width:80px;”>first class</p><p style=”width:160px;”>Free changepermitted within same class if available at least 4 days prior to departure.</p><p style=
“width:160px;”>20% of fare charged (minimum CNY50 charge). </p><p style=”width:160px;”>Can not be endorsed</p></div>
———————–style————————
.list b{display: -moz-inline-stack;display: inline-block;zoom:1;*display:inline; vertical-align:middle;height:50px;border:solid 1px #88cd3e;background-color:#ce6;}
复制代码
添加空元素之后,问题就解决了。
完整代码:


<!DOCTYPE HTML>
          <html>
           <head>
            <meta meta charset="utf-8">
            <title>Demo</title>
            <style type="text/css" media="all">
             body{color:black;background-color:white;padding:50px;font-size: 12px;line-height:16px;font-family:arial; color: #1E346E;}
             * {margin: 0;padding:0;border-width: 0;}
             .list{vertical-align: middle;width:640px;margin-bottom: 1px;border: solid 1px #00a0da;background-color:#F0F5FF; }
             .list:hover{background-color:#d9e7f5;}
             /*----------set vertical align middle----------*/
             .list p,.list b { vertical-align: middle;display: -moz-inline-stack;display:inline-block;zoom:1;*display:inline;}
             .list p { padding:10px;}
             /*----------set min-height----------*/
             .list b { height:52px;width:1px;overflow:hidden;margin-left:-1px;background-color:#009Cd0;}
            </style>
           </head>
           <body>
            <div class="list"><b> </b><p style="width:80px;">first class</p><p style="width:160px;">Can be modified</p><p style="width:160px;">Can be refunded.</p><p style="width:160px;">Can be endorsed</p></div>
            <div class="list"><b> </b><p style="width: 80px;">Economy class</p><p style="width:160px;">Can be modified</p><p style="width:160px;">Can be refunded.</p><p style="width:160px;">Can be endorsed</p></div>
            <div class="list"><b> </b><p style="width:80px;">23% off Economy class</p><p style="width:160px;">One free change permitted within same class if available; further changes charged 10% of fare. Passengers must go to CA ticketing office to process fee-based changes.</p><p style="width:160px;">10% of fare charged. </p><p style="width:160px;">Can not be endorsed</p></div>
            <div class="list"><b> </b><p style="width:80px;">-6% off Economy class</p><p style="width:160px;">Free change permitted within same class if available at least 4 days prior to departure.</p><p style="width:160px;">20% of fare charged (minimum CNY50 charge).</p><p style="width:160px;">Can not be endorsed</p></div>
           </body>
          </html>

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2024-11-22 05:31 , Processed in 0.042190 second(s), 9 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表