zoukankan      html  css  js  c++  java
  • css中vertical-align和line-height的用法

    css中vertical-align和line-height的用法

    1、先来看一种现象:

      (1)、将一个图片放入一个div块中,div块背景颜色设置为aquamarine。将会发现图片与div块下边沿有一定间隙。

          实例:

             

          代码如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>css中vertical-align和line-height的用法</title>
        <style>
            *{
                margin: 0px;
                padding: 0px;
            }
            div{
                background-color: aquamarine;
            }
            img {
                width: 300px;
            }
        </style>
    </head>
    <body>
        <div>
            <img src="./131796750659172.jpg" alt="picture">
        </div>
    </body>
    </html>
    View Code

      (2)、在div块的图片后面放入一个span标签,内容为xxxx!,会发现span标签内的元素与图片是在底线对其的,当给span加一个背景时,可以看到图片底部是与字母x底部对齐的。

        实例:

          

          实例:放大之后可以很明显的看出来!

          

          代码如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>css中vertical-align和line-height的用法</title>
        <style>
            *{
                margin: 0px;
                padding: 0px;
            }
            div{
                background-color: aquamarine;
            }
            img{
                width: 300px;
            }
            span{
                background-color: azure;
            }
        </style>
    </head>
    <body>
        <div>
            <img src="./131796750659172.jpg" alt="picture">
            <span>xxxxx!</span>
        </div>
    </body>
    </html>
    View Code

          为什么会出现这种现象呢?

      答:原因是行内元素默认都受vertical-align(垂直对齐方式)和line-height(行高)的影响,而vertical-align默认的对齐方式是baseline,即基线对齐。这个基线就是span标签里的字母X的下边沿,故图片底部是与字母底部相对齐的(不是与span标签的背景对齐)。又因为字母本身有line-height(行高)值,所以span标签加上背景后比字母要高一些。

          解决方法:(四种方法任意一种都可解决该问题)

      (1)、将整个div内的font-size设置为0;

      (2)、将图片img变为块级元素,即设置其为display:block;

      (3)、给div设置一个行高(值尽量小些),设置为line-height:5px;

      (4)、设置图片img垂直对齐方式vertical-align,值为top/middle/bottom任意一个都可以(为了覆盖默认的值baseline);

        效果如下:

        

        完整代码如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>css中vertical-align和line-height的用法</title>
        <style>
            *{
                margin: 0px;
                padding: 0px;
            }
            div{
                background-color: aquamarine;
                /*line-height: 5px;*/
                /*font-size: 0;*/
            }
            img{
                width: 300px;
                /*display: block;*/
                vertical-align: bottom;
            }
            span{
                background-color: azure;
            }
        </style>
    </head>
    <body>
        <div>
            <img src="./131796750659172.jpg" alt="picture">
            <span>xxxxx!</span>
        </div>
    </body>
    </html>
    View Code

    2、图片垂直居中的问题

        在div和img中添加以下属性及属性值即可实现图片在div块中的垂直居中。

    <style type="text/css">
    ...
    
    div{
        line-height: 500px;
        font-size: 0px;
    }
    img{
        vertical-align: middle;
    }
    
    ...
    <style>

        效果如下:

           

        代码如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>css中vertical-align和line-height的用法</title>
        <style>
            *{
                margin: 0px;
                padding: 0px;
            }
            div{
                background-color: aquamarine;
                line-height: 500px;
                font-size: 0px;
            }
            img{
                width: 300px;
                vertical-align: middle;
            }
            span{
                background-color: azure;
            }
        </style>
    </head>
    <body>
        <div>
            <img src="./131796750659172.jpg" alt="picture">
            <span>xxxxx!</span>
        </div>
    </body>
    </html>
    View Code

        本文出处:http://www.zhangxinxu.com/wordpress/2015/08/css-deep-understand-vertical-align-and-line-height/

  • 相关阅读:
    线性时不变系统的频率选择滤波器
    Why Programmmers dont have a High Social Status?
    Oracle 的DBA考证
    基于matlab的FIR加窗滤波器设计
    奥本海姆《离散时间信号处理》第二版书评
    Altium Designer 发现的机密——摘自CRAZY BINGO
    sql server 2008 添加登录名
    Silverlight listbox横向排列
    IOS 摄像头使用(1)UIImagePickerController
    ios 如何获得系统时间和日期
  • 原文地址:https://www.cnblogs.com/gaotenglong/p/5708793.html
Copyright © 2011-2022 走看看