CSS学习31-vertical-align属性应用

Posted Brianxq

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CSS学习31-vertical-align属性应用相关的知识,希望对你有一定的参考价值。


vertical-align 属性应用

CSS 的 vertical-align 属性使用场景:经常用于设置图片或者表单 ( 行内块元素 ) 和文字垂直对齐。

官方解释:用于设置一个元素的垂直对齐方式,但是它只针对于行内元素或者行内块元素有效。

语法:

vertical-align: baseline | top | middle | bottom;
描述
baseline 默认。元素放置在父元素的基线上。
top 把元素的顶端与行中最高元素的顶端对齐。
middle 把此元素放置在父元素的中部。
bottom 把元素的顶端与行中最低的元素的对齐。

image-20210607164846936


1. 图片、表单和文字对齐

图片、表单都属于行内块元素,默认的 vertical-align 是基线对齐。

此时可以给图片、表单这些行内块元素的 vertical-align 属性设置为 middle 就可以让文字与图片垂直居中对齐了。

示例代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>利用vertical-align实现图片文字垂直居中对齐</title>
    <style>
        img {
            /* vertical-align: bottom; */
            /* 让图片和文字垂直居中 */
            vertical-align: middle;
            /* vertical-align: top; */
        }

        textarea {
            vertical-align: middle;
        }
    </style>
</head>

<body>
    <img src="images/ldh.jpg" alt=""> 刘德华
    <br>
    <textarea name="" id="" cols="30" rows="10"></textarea> 请您留言
</body>

</html>

运行结果

image-20210607164941593


2. 解决图片底部默认空白缝隙问题

bug:图片底侧会有一个空白缝隙,原因是行内块元素会和文字的基线对齐。

主要的解决办法有两种:

  1. 给图片添加 vertical-align: baseline | top | middle | bottom; 等。( 提倡使用的 )
  2. 把图片转换为块级元素 display: block;

示例代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>图片底侧空白缝隙解决方案</title>
    <style>
        div {
            border: 2px solid red;
        }

        img {
            /* vertical-align: bottom; */
            display: block;
        }
    </style>
</head>

<body>
    <div>
        <img src="images/ldh.jpg" alt="">
    </div>
</body>

</html>

运行结果

image-20210607165937279

以上是关于CSS学习31-vertical-align属性应用的主要内容,如果未能解决你的问题,请参考以下文章

定义总体overflow样式后应怎样消除此效果

css的三个特性 背景透明设置

C1认证学习二十二十一二十二(CSS背景属性CSS文本属性)

C1认证学习二十二十一二十二(CSS背景属性CSS文本属性)

CSS学习20-CSS属性书写顺序

css学习笔记——CSS3 transition 属性