如何让css文字垂直居中(上)

如何让css文字垂直居中(上)其实可以很容易地实现 CSS 文字的水平居中 但是有时候我们需要将文字垂直居中 除了表格实现这种 CSS 文字的垂直居中之外 还有很多其他的方式注意 下面的 demo 只适用于现代浏览器 不兼容 IE 的低版本和其他非主流浏览器 实现 css 文字垂直居中的 8 种方法如下 1 使用绝对定位和负外边距对块级元素进行垂直居中 css 垂直居中效果 css 垂直居中实现代码 这个方法兼容性不错 但是有一个小缺点 必须提前知道被居中块级元素的尺寸 否则无法准确实现垂直居中 2 使用绝对定位和 transform 代码如下

其实可以很容易地实现 CSS文字的水平居中,但是有时候我们需要将文字垂直居中,除了表格实现这种 CSS文字的垂直居中之外,还有很多其他的方式

注意:下面的 demo只适用于现代浏览器,不兼容 IE的低版本和其他非主流浏览器。

css垂直居中实现代码:

这个方法兼容性不错,但是有一个小缺点:必须提前知道被居中块级元素的尺寸,否则无法准确实现垂直居中。

这种方法非常明显的好处就是不必提前知道被居中的元素的尺寸,因为transform中偏移的百分比就是相对于元素自身的尺寸而言。

3.绝对定位结合margin:auto

这种方式的两个核心是:把要垂直居中的元素相对于父元素绝对定位,top和bottom设置为相等的值,我这里设置成0了,当然也可以设置为99999px或者-99999px,无论什么,只要两者相等就行。这一一步做完之后再将要居中的元素的margin设为auto,这样就可以实现垂直居中了。

被居中元素的宽度也可以不设置,但是不设置的话,就必须是图片这种自身就包含尺寸的元素,否则无法实现。

4.使用padding实现子元素的垂直居中

这种方式非常简单,就是给父元素设置相等的上下内边距,则子元素自然是垂直居中的,自然这个时候父元素是不能设置高度的,要让它自动被填充起来,除非设置了一个正好等于上内边距+子元素高度+下内边距的值,否则无法精确地垂直居中。

这种方式看似没有什么技术含量,但其实在某种场景下也是非常好用的。

5.使用flex布局

flex布局(弹性布局/伸缩布局)里门道颇多,这里先针对用到的东西简单说一下,想深入学习的小伙伴可以去看阮一峰老师的博客。

flex也就是flexible,意思为灵活的,柔韧的,易弯曲的。

元素可以通过设置display:flex;将其指定为flex布局的容器,指定好了容器之后再为其添加align-items属性,该属性定义项目在交叉轴(这里是纵向周)上的对齐方式,可能的取值有五种,分别如下:

flex-start:交叉轴的起点对齐;flex-end:交叉轴的重点对齐;

center:交叉轴的重点对齐;baseline项目第一行文字的基线对齐;

strech(该值是默认值):如果项目没有设置高度或者设置为auto,那么将占满整个容器的高度。

6.弹性布局

这种方式也是给父元素设置display:flex,设置好之后改变主轴的flex-direction:column,该属性可能的取值有四个,分别如下:

row(该值为默认值):主轴为水平方向,起点在左端;

row-reverse,主轴是水平方向,起点在有端;

column主轴为垂直方向,起点在上沿;

column-reverse:主轴为垂直方向,起点在下沿。

justify-content属性定义了项目在主轴上的对齐方式,可能取的值有五个,分别如下(不过具体的对齐方式与主轴的方向有关,以下的值都是假设主轴为从左到右的):

flex-staart(该值是默认值):左对齐;

flex-end:右对齐;

center:居中对齐;

space-between:两端对齐,各个项目之间的间隔均对齐;

space-around:各个项目两侧的间隔相等。

7.还有一种在前面已经见到过很多次的方式就是使用line-height对单行文本进行垂直居中

这里有一个小坑需要大家注意:line-height(行高)的值不能设为100%;我们来看看官网文档中给出的关于line-height取值为百分比时候的描述:基于当前字体尺寸的百分比行间距,所以大家就明白了,如果是百分比是相对于字体尺寸来讲的。

8.使用display和vertical-align对容器里的文字进行垂直居中

vertical-align属性仅适用于具有 valign特性的 html元素,比如表格元素中的< td>< th>等,而诸如< div>< span>等元素则不适用。

valign属性指定了单元格中内容的垂直排列,语法为:< tdvalign=” value”>,其中 value可以有四种类型:

top:向上对齐内容

Middle:居中对齐内容

盒子:对内容进行下对齐

Baseline:基线校准

对于 baseline值:基线是一个想象中的线。行文本中的大部分字母都以基线为基准。在 baselineseselines行中,所有表数据共享同一个基线。这个值的效果通常和 bottom值一样。但是,如果文字有不同的字体大小,那么 baseline就更好了。

转自脚本之家www.bjsbarclay.com

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233584.html原文链接:https://javaforall.net

(0)
上一篇 2025年7月7日 下午1:01
下一篇 2025年7月7日 下午1:22


相关推荐

  • 苹果x充电慢是什么原因_冬季冬季婴儿游泳馆水温上升慢是什么原因呢?该怎么办呢?…[通俗易懂]

    最近,天气越来越冷,正是婴儿游泳馆旺季之时,不少婴儿游泳馆经营者却反映,自己家的热水器好像不太给力了,水温上升速度很慢,已经影响了正常的经营。那么,冬季冬季婴儿游泳馆水温上升慢是什么原因呢?该怎么办呢?热水器安装位置不对空气能热水器需要安装在通风处,好安装在阳台。阳台是个半开放空间,可以自主掌握。冬季有利于新风机置换空气,夏季可以当空调使用,保证热水器的正常运行。其他热水器也要按照使用说明,选…

    2022年4月7日
    43
  • 施密特触发器原理图解

    施密特触发器原理图解施密特触发器原理图解详细分析重要特性 施密特触发器具有如下特性 输入电压有两个阀值 VL VH VL 施密特触发器通常用作缓冲器消除输入端的干扰 nbsp 施密特波形图 施密特触发器也有两个稳定状态 但与一般触发器不同的是 施密特触发器采用电位触发方式 其状态由输入信号电位维持 对于负向递减和正向递增两种不同变化方向的输入信号 施密特触发器有不同的阀值电压 门电路有一个阈

    2026年3月20日
    4
  • AI大模型迎来“大考” 讯飞星火表现抢眼

    AI大模型迎来“大考” 讯飞星火表现抢眼

    2026年3月14日
    2
  • memset函数为二维数组初始化

    memset函数为二维数组初始化1int a a newint 10 sizeof a 只会返回出来指针的大小 所以我们只能自己计算这个数组的长度 这里应当是 sizeof int 10 因为数组里面有 10 个 int 所以应该 memset a 0 sizeof int 10 将 a 数组初始化为 02 intp 开一个 n m 的数组 p newint n for inti

    2026年3月19日
    1
  • 纯函数与副作用

    纯函数与副作用现代的 JS 有许多概念或者说一些编程技巧 这些概念有来自于其他语言 一些设计模式或者 js 语言特有的概念等 下面就来说一下与函数式编程密切相关的两个概念 纯函数和副作用副作用在计算机科学中 函数副作用指当调用函数时 除了返回函数值之外 还对主调用函数产生附加的影响 例如修改全局变量 函数外的变量 或修改参数 维基百科例如在 javascript 的内置的一些函数是有副作用的 1 2 3 pop 每次执行 pop 函数 原数组都会减少一个元素 1 2 3 splic

    2026年3月17日
    2
  • mybatis拦截器详解_短信拦截器

    mybatis拦截器详解_短信拦截器Mybatis拦截器介绍目录前言Interceptor接口注册拦截器Mybatis可拦截方法利用拦截器进行分页  拦截器的一个作用就是我们可以拦截某些方法的调用,我们可以选择在这些被拦截的方法执行前后加上某些逻辑,也可以在执行这些被拦截的方法时执行自己的逻辑而不再执行被拦截的方法。Mybatis拦截器设计的一个初衷就是为了供用户在某些时候可以实现自己的逻辑而不必去动Mybatis…

    2025年10月12日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号