原文地址:http://topic.csdn.net/u/20100702/15/e0087252-0975-424b-8b9b-ce6c6cb3699d.html
向作者致敬!
昨天在论坛里溜达的时候,发现有同学遇到了居中的问题,页面在 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”:
HTML code
<!--
Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/
-->
<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>
分享到:
相关推荐
在设计网页时,居中对齐是一种常见的需求,`text-align:center;` 是CSS中用于实现文本水平居中的一个属性。然而,当在Internet Explorer 7(简称IE7)这个较旧的浏览器版本中使用该样式时,可能会遇到一个问题:文本...
通常,`text-align: left` 会使文本左对齐,`text-align: right` 使文本右对齐,而 `text-align: center` 则将文本居中。然而,`justify` 提供了一种更专业且对称的文本排列效果,尤其适合长段落的阅读体验。 在IE...
- **IE6/7/8的混杂模式**:在这个版本的IE浏览器中,`text-align:center`可以使块级元素也居中对齐,这与标准规定不符。 - **其他浏览器**:在Firefox、Chrome、Safari等浏览器中,`text-align:center`仅作用于行内...
如果想要让多个`<div>`元素在同一行中居中对齐,可以将它们的`display`设置为`inline-block`,并设置`vertical-align`为`middle`。需要注意的是,当使用`vertical-align: middle`时,通常还需要配合`line-height`...
这样,我们可以用 `vertical-align: middle` 实现垂直居中,再配合 `text-align: center` 实现文字的水平居中。具体代码如下: ```html <div class="text"> Multi-line, vertical-align:middle; text-align:...
1. 居中对齐:可以使用CSS的`text-align: center;`属性将表单元素整体居中。 2. 左对齐或右对齐:使用`text-align: left;`或`text-align: right;`来调整元素的对齐位置。 3. 使用Flexbox布局:通过设置`display: ...
1. `text-align:center`主要用于内联元素和文本的居中对齐,而`margin:0 auto`则用于块级元素的居中。 2. 在IE浏览器中,`text-align:center`会同时作用于段落`<p>`和内联元素`<img>`,使两者都居中。但在Firefox中...
`属性可以轻松地将文本内容在div内居中对齐。例如: ```css .container { text-align: center; } ``` 2. **多行文本水平居中**: 对于多行文本,`display: flex;`和`justify-content: center;`组合可以实现...
在Web开发中,实现元素的水平垂直居中对齐是一个常见的布局需求。传统上,我们会使用Flexbox或CSS Grid等现代CSS布局技术来实现这一目标。但是,利用`vertical-align:middle`属性也能达到类似的效果,并且在某些情况...
对于IE6,由于其特性,需要在`body`标签中设置`text-align: center`,然后在需要居中的元素上设置`text-align: left`,以确保内容居中而文本仍保持左对齐。 ```css body { text-align: center; } #wrap { text-...
`: 居中对齐。 - `vertical-align: bottom;`: 底部对齐。 **5. 显示模式 (`display`):** - `display: block;`: 块级元素。 - `display: inline;`: 内联元素。 - `display: list-item;`: 列表项。 - `display: ...
在网页布局中,让元素居中对齐是一个常见的需求,特别是在开发过程中,我们需要确保页面在各种浏览器下都能正常显示。通常,我们有两种主要的方法来实现元素的水平居中:`text-align:center` 和 `margin: auto`。这...
其中,元素的居中对齐是常见的需求,无论是水平居中还是垂直居中,都可能在各种场景中遇到。以下将详细讲解几种常用且有效的CSS居中方法。 1. **水平居中** - **Text-align属性**:适用于内联元素或块级元素容器...
通过将`text-align`属性设置为`center`,可以使得元素内的文本居中,如果将这个属性应用到容器元素(如`body`),则容器内的所有子元素也会居中。但这是一种hack,因为`text-align`通常用于控制文本而不是整个元素...
在网页设计中,实现元素的居中对齐是一项常见的需求,特别是对于图片和多行文字的垂直居中。在本文中,我们将深入探讨如何利用CSS来实现这一目标,主要关注JavaScript标签下的CSS技巧。 首先,让我们分析给出的HTML...
但是,这种方法实际上会影响到所有子孙元素,导致它们也都居中对齐。为了修复这个问题,需要对子元素单独设置`text-align: left`。例如: ```css body { text-align: center; } p { text-align: left; } ```...
在CSS中,可以使用`text-align:center;`属性来使内部的内容居中对齐。例如: ```css body { text-align: center; } ``` 然而,这种方法仅适用于文本内容的居中,对于包含浮动元素(如使用`float:left`或`float:...
设置`text-align: center`到父元素,如`body`,可以使元素内部的内容居中。但这种方式会导致所有子孙元素都居中,所以通常需要额外的CSS规则来恢复默认的左对齐: ```css body { text-align: center; } ....
【Div+CSS布局居中】是网页设计中常见的需求,主要涉及到CSS的布局技术,特别是元素的居中对齐方式。以下将详细讲解几种常见的CSS居中方法。 1. **使用自动外边距实现居中** 这是CSS中推荐的让元素水平居中的方法...