你的元素居中对齐了吗?——关于 'text-align:center' 的问题

转自:http://bbs.youkuaiyun.com/topics/340170231

 

 昨天在论坛里溜达的时候,发现有同学遇到了居中的问题,页面在 IE 里居中对齐好好的,为什么在其他浏览器里面就不灵了呢?
    我曾经也在写一个 JS 日历的时候也被居中弄的焦头烂额,苦不堪言。想必不少人都遇到过这个问题吧。
    我大致看了一下,发现是 “text-align:center” 的兼容性引起的。下面就这个问题跟大家分享一点我的经验。
    先来看看 W3C 标准中是怎么说的。
    在W3C CSS2.1规范第16.2节 对text-align 有详细地描述: ------------------------------------------ 值: left | right | center | justify | inherit 初始值:匿名值,由'direction'的值而定,如果'direction'为'ltr'则为'left',如果'direction'为'rtl'则为'right'。 应用于: 块级元素,表格单元格,行内块元素 继承性: 是 计算后的值:初始值或指定值 ------------------------------------------
    这个特性描述了如何使一个块元素的行内内容对齐。
    注意一点,标准里说这个属性是用来对齐行内内容的,所以,应该对块级内容起作用。
    解释一下,行内内容是说由行内元素组成的内容,行内元素大家都知道吧,比如 SPAN 元素,IFRAME元素和元素样式的 ‘display : inline’ 的都是行内元素;块级内容跟则是由块级元素构成,DIV 是最常用的块级元素。块级元素和行内元素的区别是,块级元素会占一行显示,而行内元素可以在一行并排显示。
    这样,我们对这个特性的认识应该就清楚了。但是,问题来了,虽然标准里这么规定,那么是不是所有浏览器都遵守呢?答案是否定的。猜猜是哪个浏览器这么特立独行啊? IE!!
    IE6/7及IE8混杂模式中,text- align:center可以使块级元素也居中对齐。其他浏览器中,text-align:center仅作用于行内内容上。
    解决这个问题比较好的方式,就是为所有需要相对父容器居中对齐的块级元素设置“margin-left:auto; margin-right:auto”。但这个方式 IE6/IE7/IE8的混杂模式中不支持,所以还要设置父容器的 "text-align:center;"。
    若居中对齐的子元素内的行内内容不需要居中对齐,则还需要为其设置“text-align:left”:

XML/HTML code
 
?
1
2
3
4
5
6
7
8
9
10
< style >
    * { font-family:Consolas,Verdana,Arial; font-size:12px; }
    div, center { border:3px solid dimgray; padding:2px; }
    span { background:lightgrey; }
</ style >
< div  style = "width:200px; text-align:center;" >
    < div  style = "width:100px; margin:0 auto; text-align:left;" >
        < span >text</ span >
    </ div >
</ div >

转载于:https://www.cnblogs.com/mawenying/p/5363844.html

### CSS `align-items: center` 与 `text-align: center` 的区别 #### 定义和应用场景 - **`text-align: center`** 适用于块级元素内的行内元素(如文本、行内块元素),主要用于水平居中文本或其他行内内容。此属性不会影响块级元素本身的位置,仅对其内部的行内内容起作用[^1]。 ```html <div style="text-align: center;"> 这里是一些居中的文字。 </div> ``` - **`align-items: center`** 属于 Flexbox 布局的一部分,应用于弹性容器(即设置了 `display: flex` 或者 `inline-flex` 的元素)。它控制的是所有弹性项目的交叉轴上的对齐方式,可以使项目在垂直方向上居中(当主轴为水平时)[^2]。 ```css .container { display: flex; align-items: center; /* 子项沿交叉轴中心对齐 */ } ``` #### 使用示例对比 ##### HTML 结构相同: ```html <!-- 父级 --> <div class="parent"> <!-- 子级 --> <span>一段文字</span> </div> ``` ##### 应用不同的CSS样式效果如下: ###### 当应用 `text-align: center`: ```css .parent { width: 300px; height: 100px; border: 1px solid black; text-align: center; } .child { background-color: lightblue; } ``` 这会使 `<span>` 中的文字在 `.parent` 内部水平居中显示,但是整个 `<span>` 元素仍然位于顶部,因为 `text-align` 不会影响其垂直位置。 ###### 而如果改用 `align-items: center` 并启用 Flexbox : ```css .parent { display: flex; justify-content: center; /* 主轴(默认水平)居中 */ align-items: center; /* 交叉轴(此时垂直)居中 */ width: 300px; height: 100px; border: 1px solid black; } .child { background-color: lightcoral; } ``` 这样不仅可以让子元素中的文本保持水平居中,还能让这个子元素整体相对于父元素在垂直方向也实现了居中排列[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值