IE6/IE7不识别display:inline-block属性怎么办
来源:互联网 发布:手绘照片软件叫什么 编辑:程序博客网 时间:2024/05/17 04:39
IE6/IE7不识别display:inline-block属性怎么办
鉴于inline元素的这种特性,如果我们不浮动并且想让li显示在一行,而且可以设置高度,宽度以及上下margin,上下padding等属性,应该怎么办呢?你一定会想到一个属性display:inline-block;对!”inline- block”就是干这个事的,让一个元素既不换行又具有block元素的特性。不过有点小问题.
在IE6、IE7中不识别display:inline-block属性,加不加display:inline-block;对于它们完全没有任何影响。那么让我们来想办法解决这个问题,这就涉及到ie6,7中的haslayout属性了。ie6,7中的inline元素有个特殊的情况,就是触发了ie的hasLayout属性以后就拥有了layout。此时inline元素的表现和标准浏览器里面的inline-block元素基本相同。
看下面这个例子,我们用ie的私有属性zoom来触发hasLayout,然后看看inline元素的表现。
<html xmlns=”http://www.w3.org/1999/xhtml”> <head> <meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″ />
<title>display-block</title>
<style>
span {
width:200px;height:50px;margin:10px;padding:20px;background:#ccc;zoom:1;
}
</style>
</head>
<body>
<span>span</span>
</body>
</html>
可以看到在ie6,7中inline元素span已经表现得和一个display:inline-block元素一摸一样了,但是在标准浏览器中span仍然是行内元素(宽高以及上下margin都无效)。
如果声明了不正确DTD,导致ie6在quirks 模式下解析,那么ie6会自动触发inline元素的haslayout,不过这里只讨论正常情况下的解析,所以加了个zoom:1来触发haslayout;zoom的值设置为除了auto外的任何值都会触发haslayout,之所以经常用zoom:1;是因为zoom这个属性本身是ie的缩放属性,设置为其他值会导致元素在ie下变形,设置为1既是保持原形不缩放。
了解了上面的情况,我们就可以来解决之前那个问题了。可以改原先的css代码如下:
li {
display:inline-block; /* firefox等标准浏览器识别*/
*display:inline; /* 只有ie6和ie7识别*/zoom:1; /* 触发ie6和ie7下的haslayout */
width:80px;
height:20px;
margin:10px;
padding:10px;
text-align:center;
background:#cfc;
}
让标准浏览器识别display:inline-block;让ie6,7识别display:inline;来覆盖上面的display:inline-block;(我为什么要说”覆盖”?)。然后通过zoom:1;来触发haslayout让inline元素在ie中表现得和inline-block元素一样。
<html xmlns=”http://www.w3.org/1999/xhtml”><head><meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″ /><title>display-block</title><style>
ul {
background:#ccc;padding:0;margin:0;list-style:none;
}li {
display:inline-block;*display:inline;zoom:1;width:80px;height:20px;margin:10px;padding:10px;text-align:center;background:#cfc;
}
</style></head><body>
<ul>
<li>测试</li><li>测试</li><li>测试</li><li>测试</li>
</ul>
</body></html>可以看到,现在在各浏览器里面的显示已经一致了。li元素都显示在同一行。
http://www.poluoluo.com/jzxy/201206/167493.html
- IE6/IE7不识别display:inline-block属性怎么办
- IE6和IE7不能识别display:inline-block的解决办法
- display:inline-block 不被IE7识别的解决方案
- IE6/Ie7 display:inline-block 不起作用
- display:inline-block; IE6/IE7 兼容问题
- "display: inline-block;"不兼容IE6
- ie6 ie7 的div 对 display:inline-block的解析
- display:inline-block在IE6/Ie7和IE8中的区别
- 让IE6/IE7 支持 display:inline-block 的方法
- display:inline-block在ie6,7下无法识别解决方法
- display:inline-block; IE7不兼容采用hack解决之道
- display:inline-block属性
- display:inline-block属性
- IE6:display:inline-block解决方案
- display属性值:block,inline-block,inline
- display属性 inline block inline-block区别
- css display属性:inline、block、inline-block
- 实现三个div同一行显示,IE6 and Ie7 :display:inline-block
- Xml和DataSet互转
- 全面兼容ie6,ie7,ie8,ff的CSS HACK写法
- SystemUI中状态栏跟导航栏隐藏显示控制方法及效果示例
- [Ext JS 4] 实战之Grid, Tree Gird 动态添加列
- 省市级天气查询--Api接口
- IE6/IE7不识别display:inline-block属性怎么办
- 简述两个主机如何实现通讯
- uitableviewcell 的head view
- 使用cpplint进行提交代码的风格检查
- 单链表和之恋 Bitwise add
- 光流法——Opencv
- 一个输出恒为true的问题
- AJAX入门实例一
- 非阻塞读终端与等待超时