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

WebAdvocate 2010-07-02 03:07:00
加精
昨天在论坛里溜达的时候,发现有同学遇到了居中的问题,页面在 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”:

<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>

...全文
12841 117 打赏 收藏 转发到动态 举报
写回复
用AI写文章
117 条回复
切换为时间正序
请发表友善的回复…
发表回复
叶子的翅膀 2012-11-02
  • 打赏
  • 举报
回复
cs02308 2012-09-05
  • 打赏
  • 举报
回复
tmd,每次弄这个都得去查浏览器的版本,看看支持不支持,强烈鄙视微软,每个IE都可以当成不同浏览器处理,火狐和Google的浏览器还是有很多不兼容的地方。IE9设置text-align:center和margin:0px auto;完全不起作用。
昵称不好起 2011-12-20
  • 打赏
  • 举报
回复
楼猪好像很负责似的
qiang5233 2011-10-28
  • 打赏
  • 举报
回复
这都说强,你们不是做前端的吧
小卢子 2011-06-28
  • 打赏
  • 举报
回复
顶一下~
yanliping1107 2011-02-15
  • 打赏
  • 举报
回复
为什么我在IE7、ie8和firefox下text-align: center对块级元素都能居中.
langfutao 2010-11-29
  • 打赏
  • 举报
回复
搞到半夜了,才在你这里解决了这个问题!
glaivelee 2010-09-28
  • 打赏
  • 举报
回复
唉, 前两天遇到这个问题忙了半天,怎么没早看到此帖.
zxingdream 2010-09-16
  • 打赏
  • 举报
回复
呵呵 又学习了,
温溪 2010-09-15
  • 打赏
  • 举报
回复
......................
zsvslx 2010-09-08
  • 打赏
  • 举报
回复
顶下 太好了
xcf007 2010-08-27
  • 打赏
  • 举报
回复
<!DOCTYPE HTML>
飘过~
黑白丶Love 2010-08-26
  • 打赏
  • 举报
回复
学习、、顶一下
hjx2710 2010-08-15
  • 打赏
  • 举报
回复
最近在做页面遇到好多CSS兼容性的问题,头疼
myth_628 2010-08-13
  • 打赏
  • 举报
回复
[Quote=引用 99 楼 himajie 的回复:]
最近在IE上开发些东西在火狐上老不兼容。郁闷死了
[/Quote]
开发的时候一边开一个浏览器看就好,虽然开发的时候比较费时,不过整体下来能省不少时间
himajie 2010-08-13
  • 打赏
  • 举报
回复
最近在IE上开发些东西在火狐上老不兼容。郁闷死了
bolahbc 2010-08-12
  • 打赏
  • 举报
回复
=。=顺便学习
phf0313 2010-08-12
  • 打赏
  • 举报
回复
哦。挺麻烦的。
五谷杂粮_007 2010-08-11
  • 打赏
  • 举报
回复
学习了
jiangshan0318 2010-07-26
  • 打赏
  • 举报
回复
IE6/7及IE8混杂模式中,text- align:center可以使块级元素也居中对齐。其他浏览器中,text-align:center仅作用于行内内容上。

我试了一下,好像只有IE6和IE7支持块元素之间的text- align:center。
个人觉得text- align:center完全可以去掉,margin:0px auto;完全可以在各个浏览器中实现块状元素的居中效果。
路过路过,纯属个人意见哈
加载更多回复(86)

5,006

社区成员

发帖
与我相关
我的任务
社区描述
解读Web 标准、分析和讨论实际问题、推动网络标准化发展和跨浏览器开发进程,解决各种兼容性问题。
社区管理员
  • 跨浏览器开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧