浏览器 文字类型 元素排版中,存在用于对齐的 基线 ,一般情况下,默认是基线对齐,这就会产生一些元素对不齐、有缝隙之类的问题,面对这些问题,我们可以用垂直对齐方式来解决。
垂直对齐方式
我们在设置图文样式的时候,可以发现,当图片和文字在一行中显示时,其实它们的底部是不对齐的,对于这类问题,可以用 垂直对齐 方式来解决。
垂直对齐方式可以解决 行内 / 行内块 元素的垂直对齐问题,其属性名是 vertical-align
,它有 4 个属性值:
- baseline :基线对齐,默认值
- top :顶部对齐
- middle :中部对齐
- bottom :底部对齐
项目中 vertical-align 可以解决的问题
(1)文本框和表单按钮无法对齐问题
可以看到下例中,搜索按钮稍微有点上移,与输入框没有对齐:
HTML
<body>
<input type="text" />
<input type="button" value="搜索" />
</body>
<style>
input {
height: 60px;
box-sizing: border-box;
}
</style>
data:image/s3,"s3://crabby-images/89fdd/89fdd26f843f47e2c8783f01354b89ce49a18cc6" alt=""
在上例基础上,给元素设置垂直对齐方式:中部对齐
HTML
<body>
<input type="text" />
<input type="button" value="搜索" />
</body>
<style>
input {
height: 60px;
box-sizing: border-box;
vertical-align: bottom;
}
</style>
data:image/s3,"s3://crabby-images/3fa83/3fa838f72e5ef5f14de0d05ec804ad7f5a11d72c" alt=""
(2)input 系列和 img 图片无法对齐问题
HTML
<body>
<img src="./beijing1.jpeg" alt="">
<input type="text" />
</body>
<style>
input {
height: 60px;
box-sizing: border-box;
}
img{
width: 120px;
height: 120px;
}
</style>
data:image/s3,"s3://crabby-images/91297/912973e37bd62a899f2c628af84ce17e8fd462e2" alt=""
给 img 标签设置垂直对齐:以底部垂直为例
HTML
<body>
<img src="./beijing1.jpeg" alt="">
<input type="text" />
</body>
<style>
input {
height: 60px;
box-sizing: border-box;
}
img{
width: 120px;
height: 120px;
vertical-align: bottom;
}
</style>
data:image/s3,"s3://crabby-images/96468/96468234a93ad3abaf4054d46a1d5bbd2ab5614a" alt=""
(3)div 中的文本框无法贴顶问题
HTML
<style>
div {
width: 240px;
height: 80px;
background-color: rgb(51, 242, 30);
}
</style>
<body>
<div>
<input type="text" />
</div>
</body>
data:image/s3,"s3://crabby-images/b00a5/b00a5cd4ca82714722e4b3e7f9cc5312d819964e" alt=""
给输入框设置垂直对齐方式:顶部对齐
HTML
<style>
div {
width: 240px;
height: 80px;
background-color: rgb(51, 242, 30);
}
input{
vertical-align: top;
}
</style>
</head>
<body>
<div>
<input type="text" />
</div>
</body>
data:image/s3,"s3://crabby-images/a1751/a175116d18a7bbb090dc838c5eb99d3a8acfcbf6" alt=""
(4)div 不设置高度,由图片撑开,此时图片标签下面会存在额外间隙问题
HTML
<style>
div {
width: 240px;
background-color: rgb(51, 242, 30);
}
img{
width: 100px;
height: 100px;
}
</style>
</head>
<body>
<div>
<img src="./beijing1.jpeg" alt="背景">
</div>
</body>
data:image/s3,"s3://crabby-images/3fb67/3fb678c52e1ae3fff88a73b1b7a7d9527b34f1c9" alt=""
给图片设置垂直对齐方式:中间对齐
HTML
<style>
div {
width: 240px;
background-color: rgb(51, 242, 30);
}
img{
vertical-align: middle;
width: 100px;
height: 100px;
}
</style>
</head>
<body>
<div>
<img src="./beijing1.jpeg" alt="背景">
</div>
</body>
data:image/s3,"s3://crabby-images/8805a/8805a2abfb3182d671ae1eafa6c0f59373d90860" alt=""
浏览器会把行内标签和行内块标签当作文字处理,默认是基线对齐,对于上面的示例,还可以将图片标签转换成块级标签来实现,效果相同:
data:image/s3,"s3://crabby-images/30928/30928497c8d8ca370978690c29f77010e9d83240" alt=""
(5)使用行内高让图片标签居中问题
HTML
<style>
div {
width: 240px;
height: 200px;
line-height: 200px;
background-color: rgb(51, 242, 30);
}
img {
width: 100px;
height: 80px;
}
</style>
</head>
<body>
<div>
<img src="./beijing1.jpeg" alt="背景" />
</div>
</body>
data:image/s3,"s3://crabby-images/406ae/406ae5d877b5019aeb0c9c80c4a57f3fdff7d42a" alt=""
给图片设置垂直对齐方式:中间对齐
HTML
<style>
div {
width: 240px;
height: 200px;
line-height: 200px;
background-color: rgb(51, 242, 30);
}
img {
vertical-align: middle;
width: 100px;
height: 80px;
}
</style>
</head>
<body>
<div>
<img src="./beijing1.jpeg" alt="背景" />
</div>
</body>
data:image/s3,"s3://crabby-images/65908/65908673773f082a2c0999bdb7b8ec9924493988" alt=""
(6)水平、垂直都居中
HTML
<style>
div {
text-align: center;
width: 240px;
height: 200px;
line-height: 200px;
background-color: rgb(51, 242, 30);
}
img {
vertical-align: middle;
width: 100px;
height: 80px;
}
</style>
</head>
<body>
<div>
<img src="./beijing1.jpeg" alt="背景" />
</div>
</body>
data:image/s3,"s3://crabby-images/6c5af/6c5af3e6c039636e92a19de0343ec98a09ad9155" alt=""