IE6/IE7下绝对定位position:absolute和margin的冲突问题
建站知识 2021-07-03 08:43www.168986.cn长沙网站建设
我们来看一个代码
复制代码
代码如下:<div id=”layer1″ style=”margin:20px; border:1px solid #F88; width:400px; “> <div id=”layer2″ style=”position:absolute; background-color:#c;”>Absolute (layer2)</div> <div id=”layer3″ style=”margin:30px auto; width:200px; height:80px; background-color:#36F;”>Normal Text Content (layer3)</div> </div>
这个代码的效果如下
在FF和IE8下都没有任何问题的,在IE6和IE7下有人如下两个bug
a, 绝对定义(position:absolute)的相邻元素margin-失效,但如果相邻元素(layer3)去掉width属性,margin-又会生效。 b, layer1无法靠左,距离左边的距离为layer1的第一个非绝对定义元素(layer3)的margin-left值。 解决方法
1,添加代码<!–[if lte IE 7]><div></div><![endif]–>,这也是网上找到的能够完全解决问题的方法。即代码变为
复制代码
代码如下:<div style=”margin:20px; border:1px solid #F88; width:400px; “> <div style=”position:absolute; background-color:#c;”>Absolute (layer2)</div> <!–[if lte IE 7]><div></div><![endif]–> <div style=”margin:30px auto; width:200px; height:80px; background-color:#36F;”>Normal Text Content (layer3)</div> </div>
2,外围元素加position:relative定义,绝对定义元素加left和定义。此方法可以解决第二个bug,无法解决第一个bug。也有说法用padding-替代margin-的,有时可以这样,有时候毕竟不行的。代码为
复制代码
代码如下:<div style=”margin:20px; border:1px solid #F88; width:400px; position:relative”> <div style=”position:absolute; background-color:#c; left:0; :0;”>Absolute (layer2)</div> <div style=”margin:30px auto; width:200px; height:80px; background-color:#36F;”>Normal Text Content (layer3)</div> </div>
3,这是本文所要阐述的方法,相对来说比较完美一些。给绝对定义元素添加“background-color:#CCC; float:left; display:inline;”定义,背景色千万不可以去掉,如果没有背景色就加一个透明(background-color:transparent;)。即代码变为
复制代码
代码如下:<div style=”margin:20px; border:1px solid #F88; width:400px;”> <div style=”position:absolute; background-color:#c; float:left; display:inline;”>Absolute (layer2)</div> <div style=”margin:30px auto; width:200px; height:80px; background-color:#36F;”>Normal Text Content (layer3)</div> </div>
纠结了两天,时刻都在思考这个问题的解决思路,总算解决了。感谢桃子。
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML