HTML和CSS进阶:深入vertical-align

来源: http://www.w3cfuns.com/notes/33234/4e00242a93a05fc54adc4a1c5eaef8ed.html

vertical-align,很多人对这个属性感到很陌生,也不知道怎么去使用,其实这都是由于没有深入属性的本质所导致的。vertical-align属性非常复杂,但是也相当强大。这一节给大家介绍vertical-align属性最实用的技巧,而对于不常用的东西则不进行深入研究。
    W3C官方对vertical-align属性的定义有4个方面:    
(1)vertical-align属性用于定义“周围的文字、inline元素以及inline-block元素”相对于该元素基线的垂直对齐方式。这里的“该元素”指的是被定义了vertical-align属性的元素;
(2)在表格单元格中,vertical-align属性可以定义单元格td元素中内容的对齐方式。td元素是table-cell元素,也就是说vertical-align属性对table-cell类型元素有效;
(3)vertical-align属性对inline元素、inline-block元素和table-cell元素有效, 对block元素无效;
(4)vertical-align属性允许指定负长度值(如-2px)和百分比值(如50%);

    从上一节我们知道,每一行文字可以看成一个行盒子,其实每一个inline-block元素也可以看成一个行盒子。其中,每一个行盒子都有4条线:(1)顶线;(2)中线;(3)基线;(5)底线。这4条线跟英文簿中的4条线是相似的。

HTML和CSS进阶(2):深入vertical-align


    vertical-align属性中的“基线”跟line-height属性中的基线是一样的道理。在CSS中,vertical-align属性最见的属性值有4个:top(顶部对齐)、middle(中部对齐)、baseline(基线对齐)、bottom(底部对齐)。
一、 vertical-align属性取值
    vertical-align属性取值有3种情况:(1)负值;(2)百分比;(3)关键字。
  1、负值
    vertical-align属性取值可以为负值,例如“vertical-align:-2px”表示元素相对于基线向下偏移2px。此方法常常用于解决单选框或复选框与文字垂直对齐的问题。对于这个技巧,我们在下一章“表单效果”会详细介绍。
  2、百分比
    vertical-align属性取值可以为百分比,这个百分比是相对于当前元素所继承的line-height属性值决定的。
    举个例子,对于“vertical-align:50%”,假如当前元素所继承的line-height为20px,则“vertical-align:50%”实际上等价于“vertical-align:10px”。其中, vertical-align:10px”表示元素相对于基线向上偏移10px。
  3、关键字
    vertical属性取值可以为关键字,取值如下:
取值         说明
top                顶部对齐
middle        中部对齐
baseline        基线对齐
bottom        底部对齐
    除了以上这些,vertical-align属性取值还可以为text-top、text-bottom、super、sub等关键字。不过其他关键字在实际开发中很少用得上,因此我们只需要掌握top、middle、baseline、bottom这4个属性值就行。
    举例:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>vertical-align属性</title>
    <style type="text/css">
        img{width:80px;height:80px;}
        #img1{vertical-align:top;}
        #img2{vertical-align:middle;}
        #img3{vertical-align:bottom;}
        #img4{vertical-align:baseline;}
    </style>
</head>
<body>
    绿叶学习网<img id="img1" src="images/girl.png" alt=""/>绿叶学习网(<strong>top</strong>)
    <hr/>
    绿叶学习网<img id="img2" src="images/girl.png" alt=""/>绿叶学习网(<strong>middle</strong>)
    <hr/>
    绿叶学习网<img id="img3" src="images/girl.png" alt=""/>绿叶学习网(<strong>bottom</strong>)
    <hr/>
    绿叶学习网<img id="img4" src="images/girl.png" alt=""/>绿叶学习网(<strong>baseline</strong>)
</body>
</html>

 在浏览器预览效果如下:

HTML和CSS进阶(2):深入vertical-align


    分析:
    根据W3C的定义“vertical-align属性用于定义周围文字、inline元素或inline-block元素的基线相对于该元素的基线的垂直对齐方式”。在这个例子中,vertical-align属性定义了周围的文字相对于img元素基线的垂直对齐方式。
    此外,“vertical-align:baseline”和“vertical-align:bottom”是有区别的,请仔细观察预览效果。
二、vertical-align属性应用
    我们从以下3个方面来介绍一下vertical-align属性的使用情况:(1)inline-block元素;(2)inline元素和block元素;(3)table-cell元素。
  1、inline元素和inline-block元素
    在HTML中,常见的inline-block元素有2个:img元素和input元素。对于这两个inline-block元素,我们一定要记住。
    举例:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <style type="text/css">
        strong
        {
            font-size:40px;
            border:1px solid red;
        }
        span{font-size:12px;}
    </style>
</head>
<body>
    <span>绿叶学习网</span><strong>绿叶学习网</strong><span>绿叶学习网</span>
</body>
</html>


    在浏览器预览效果如下:

HTML和CSS进阶(2):深入vertical-align


    分析:
    当我们在CSS中为strong元素添加“vertical-align:center;”之后,浏览器预览效果如下:

    举例:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
    <style type="text/css">
        img{vertical-align:middle;}
    </style>
</head>
<body>
    <div>绿叶学习网<img src="images/girl.png" alt=""/>绿叶学习网(<strong>middle</strong>)        </div>
</body>
</html>

 

    在浏览器预览效果如下:

HTML和CSS进阶(2):深入vertical-align


  2、block元素
    vertical-align属性对inline元素、inline-block元素和table-cell元素有效,对block元素无效。
    举例:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
    <style type="text/css">
        div
        {
            vertical-align:middle;
            width:120px;
            height:120px;
         border:1px solid gray;
        }
    </style>
</head>
<body>
    <div><img src="images/girl.png" alt=""/></div>
</body>
</html>

   在浏览器预览效果如下:

HTML和CSS进阶(2):深入vertical-align


    分析:
    div是block元素,所以vertical-align属性对其无效。如果想要在div中实现图片的垂直居中,我们可以先为div定义“display:table-cell”,也就是将block元素转化为table-cell元素(表格单元格),然后再使用“vertical-align:middle”就可以实现了。
    举例:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
    <style type="text/css">
        div
        {
            display:table-cell;
            vertical-align:middle;
            width:120px;
            height:120px;
            border:1px solid gray;
        }
    </style>
</head>
<body>
    <div><img src="images/girl.png" alt=""/></div>
</body>
</html>

    在浏览器预览效果如下:

HTML和CSS进阶(2):深入vertical-align


    分析:
    在div中实现图片垂直居中是很常见的技巧,我们在后续章节会给大家介绍更多垂直居中的技巧。
  3、table-cell元素
    W3C定义:在表格单元格中,vertical-align属性可以定义单元格中内容的对齐方式。也就是说vertical-align属性对table-cell类型元素有效。
    这里要注意一下,table-cell元素跟inline、inline-block元素使用vertical-align是有很大区别的:
  (1)inline元素和inline-block元素的vertical-align是针对周围的元素来说,vertical定义的是周围元素相对于当前元素的对齐方式;
  (2)table-cell元素的vertical-align属性是针对自身而言。vertical-align定义的是内部子元素相对于自身的对齐方式;

    举例:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
    <style type="text/css">
        td
        {
            width:120px;
            height:120px;
            border:1px solid gray;
            vertical-align:middle;
        }
    </style>
</head>
<body>
    <table>
        <tr>
            <td><img src="images/girl.png" alt=""/></td>
            <td><img src="images/girl.png" alt=""/></td>
            <td><img src="images/girl.png" alt=""/></td>
        </tr>
    </table>
</body>
</html>

    在浏览器预览效果如下:

HTML和CSS进阶(2):深入vertical-align


  【后话】:这一章学习到的知识,估计已经狠狠地给那些天天自诩“精通CSS”的同学几巴掌了。原来,CSS也是如此的博大精深,并非我们想象中那么简单。对于HTML、CSS和JavaScript这3大核心技术,还是希望大家能够踏踏实实地深入研究,这样我们的前端之路才有可能走得更远。

转载于:https://my.oschina.net/u/2552669/blog/750489

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值