让IE也支持margin居中

谨以此篇献给那些和我一样使用 myeclipse 开发,为了在 IE 下居中一直使用 text-align:center 居中的童鞋。

废话不多说,解决办法是在 DOCTYPE 中加上 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd",如下一段简单的代码便可在主流浏览器中居中,包括IE6:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>margin auto</title>
</head>
<body>
<div style="width:100px;height:100px;margin:auto auto;background:red;">
</div>
</body>
</html>

还有的解决办法就是使用 XHTML 文件头:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>margin auto</title>
</head>
<body>
<div style="width:100px;height:100px;margin:auto auto;background:red;">
</div>
</body>
</html>

  

--------------------------后话---------------------------------------------------

我是一直使用 myeclipse 开发,不管前台后台,因为 myeclipse 生成的 jsp 文件 DOCTYPE 文件头不包含 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" dtd 文件,使得我一直认为 IE 不支持 margin 居中,再加上一个学 C# 的童鞋也是建议我不要一直使用 margin 居中,IE 对 auto 解析的不够好(引用他人,非本人观点),使得我以前都是使用 text-align 居中,想想就悲催,那多写了多少代码啊?不知伤了多少脑细胞,对于一个程序员而言,脑细胞多重要啊。

myeclipse 自动生成的文件头是:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
...

总结的经验是,没事闲了,逛逛博客园,问题不明白,问问谷老师。

---------------------------------------------------------------------------------

之前文章有误,勘正。感谢  Flymouse、 alxc 的指点。

posted @ 2011-08-25 10:37  小瓶子  阅读(3812)  评论(17编辑  收藏  举报
L
i
f
e

i
s

t
o
o

c
r
u
e
l
.

I
f

w
e

c
e
a
s
e

t
o

b
e
l
i
e
v
e

i
n

l
o
v
e
,

w
h
y

w
o
u
l
d

w
e

w
a
n
t

t
o

l
i
v
e
?