网页设计布局中为什么实用margin:0px auto; 在IE下会不居中?都有哪些原因会造成这个问题???

如题所述

一般在将div居中显示时,使用css:

复制代码
代码如下:

divX {margin:0 auto;}

此css在firefox下是好的,但是在ie下不起作用,网上看到原因如下:

复制代码
代码如下:

<div id="cnbruce">margin: 0 auto 看看内容居中否</div>

如上调试结果,IE6.0是不居中的,当然解决的办法可以是对网页主体“<body>”声明文本居中,即

复制代码
代码如下:

<style>
body{text-align:center}
#cnbruce{width:500px; background-color: #ccc; margin: 0 auto}
</style>
<div id="cnbruce">margin: 0 auto 看看内容居中否(加了body文本居中)</div>

然后,单个div的CSS居中,非要扯上<body>?

于是在不采用“<body>”声明文本居中的情况下,将DOCTYPE声明加上,立马有效果

复制代码
代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "
http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<style>
#cnbruce{width:500px; background-color: #ccc; margin: 0 auto}
</style>
<div id="cnbruce">margin: 0 auto 看看内容居中否(加了DOCTYPE声明)</div>

其实原理都知道,就是因为用这个“懒人”的HTML调试框,懒得去输入些忘却的东西,到头来还以为真相就是如此呢。。。
同样,关于“一边固定,一边自动扩展”的例子,加与不加在IE效果完全不同。
如下是不加的情况:

复制代码
代码如下:

<html xmlns=" http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>CSS布局</title>
<style type="text/css">
<!--
body {margin:0;}
#dv1 {background-color: #3399FF;float: left;width: 280px;}
#dv2 {background-color: #FFCC00;width:100%;}
-->
</style>
</head>
<body>
<div id="dv1">
<pre>#dv1 {background-color: #3399FF;float: left;width: 280px;} </pre>
</div>
<div id="dv2">
<pre>#dv2 {background-color: #FFCC00;width:100%;}</pre>
</div>
</body>
</html>

如下是添加了DOCTYPE声明

复制代码
代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "
http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>CSS布局1</title>
<style type="text/css">
<!--
body {margin:0;}
#dv1 {background-color: #3399FF;float: left;width: 280px;}
#dv2 {background-color: #FFCC00;width:100%;}
-->
</style>
</head>
<body>
<div id="dv1">
<pre>#dv1 {background-color: #3399FF;float: left;width: 280px;} </pre>
</div>
<div id="dv2">
<pre>#dv2 {background-color: #FFCC00;width:100%;}</pre>
</div>
</body>
</html>
温馨提示:内容为网友见解,仅供参考
第1个回答  2016-05-19
如果 谷歌 火狐 可以居中 那麼 你的IE 版本 是IE5 才没办法居中 现在 谁还用IE5 - -
如果不是 请上代码 帮你看看本回答被网友采纳
第2个回答  2016-05-19
是什么样的元素啊?inline的还是block的追问

block

追答

这个看不到代码真不好判断,可以调试看看是不是有其他样式覆盖了margin:0 auto;。
也有可能是上面仁兄说的,是不是浏览器的文档模式有设置了。

相似回答