作者:D大龙 | 来源:互联网 | 2020-09-13 21:20
本文来自CSS入门教程栏目,文中为大家介绍了css实现文本图标对齐的方法,具有一定的参考价值,希望可以帮助到大家。实现方法:可以使用vertical-align居中对齐方式。
开发中遇见图片跟文字放在一行显示是最常见不过的了,两个行内元素的对齐通常也是最令人头疼,有时候明明使用了最常用的对齐方法,却总还是有些许偏差,先来看一个最基本的示例:
html部分:
xx测试对齐Style-
推荐教程:CSS入门教程
css部分:
.wrap {
width: 300px;
text-align: center;
margin: 20px auto;
font-size: 14px;
}
.wrap img {
width: 20px;
}
未使用对齐方式的效果如下:
默认的对齐方式是 baseline ,也就是x字母的最下面那条线。
这也就回答了第一个问题,浏览器的图片跟文字未额外设置时是基于小写字母x的下边缘为基准,也就是 vertical-align:baseline; 。
常见的几种居中方案
1、使用 vertical-align 居中对齐方式
.wrap {
vertical-align: middle;
}
.wrap img {
vertical-align: middle;
}
当我们使用常用的 vertical-align 对齐文本和图片时,其实也是有一定的偏差的,如下图:
3、使用flex布局
display: flex;
align-items: center;
不过就算是flex布局,有时候也会出现一点儿偏差,比如:图片尺寸为偶数、字体font-size为偶数,line-height为偶数时对齐;奇数时偏上1px。
4、使用ex单位
ex就是小写字母x的高度,可以用在不受字体和字号影响的内联元素的垂直居中对齐效果。
PS:不过这种适用于图标高度跟文字一致,比如字符后面加一个箭头(点击展开)的情况,就很实用。
.wrap img {
height: 1ex;
}
5、vertical-align 数值方式的使用
vertical-align 属性值可以使用数值型和百分比值,如,还是上面的基本案列:如果图片高度是20px,文字font-size为22px时,默认对齐是文字的基线,那么图片会偏上2px,这时只需要将图片向下偏移2px,就能实现对齐效果,而且 vertical-align 这个属性的数值型具有很好的兼容性。
.wrap {
width: 100%;
padding-top: 200px;
text-align: center;
margin: 20px auto;
font-size: 22px;
height: 40px;
}
.wrap img {
width: 20px;
vertical-align: -2px;
}
相关视频教程推荐:css视频教程
以上就是css实现文本图标对齐的方法的详细内容,更多请关注 第一PHP社区 其它相关文章!