CSS教程:不被浏览器识别的display:inline-block属性怎么办
<!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=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元素一样。
<!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=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元素都显示在同一行;不过我上面问了:为什么要说覆盖?
假如我们把上面的css代码中的
1
2
|
display:inline-block; *display:inline; |
两句调换一下顺序会怎样?你会发现display:inline-block;覆盖了*display:inline;导致在ie6,7中原先的样式又失效了,这说明什么?说明ie6和ie7是认识display:inline-block的,所以我在前面说”不完全支持”而没有说”完全不支持”,嘿嘿,我可没有打自己嘴巴。之所以说”不完全支持”是因为还是有一点作用,虽然display:inline-block对ie6,7中的元素表现没有任何直接影响,但是它会触发inline元素的haslayout。只有这一个作用,让我们再回到前面的例子:
span {width:200px;height:50px;margin:10px;padding:20px;background: #ccc; display:inline-block;}
<!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=utf-8″ /> <title>display-block</title> <style> span {width:200px;height:50px;margin:10px;padding:20px;background: #ccc;display:inline-block;} </style> </head> <body> <span>span</span> </body> </html> |
可以看到,我们把zoom:1换成了display:inline-block以后,在ie6,7中span仍然和firefox等标准浏览器下一样,具有了设置的宽高和上下margin,上下padding。它表现得和display:inline-block同学一样好,不过这并不是因为display:inline-block这条声明直接生效了,而是因为display:inline-block触发了ie的haslayout属性,使得inline元素具有了inline-block的表现。
我想ie6,ie7的haslayout属性是个让人头疼的问题。在做导航条的时候,一般会用到ul li结构,大多数时候我们是把li设置为浮动,让其并排显示在同一行。还有一种方法就是设置li为display:inline;这样可以达到同样的效果,但是问题是inline元素的特性:默认无法设置宽度,高度,以及上下margin,(关于padding,情况有点特殊,在ie6,7中 inline元素是无法设置上下padding的,但是在标准浏览器里面是可以设置上下padding的);Word教程网 | Excel教程网 | Dreamweaver教程网 | Fireworks教程网 | PPT教程网 | FLASH教程网 | PS教程网 |
HTML教程网 | DIV CSS教程网 | FLASH AS教程网 | ACCESS教程网 | SQL SERVER教程网 | C语言教程网 | JAVASCRIPT教程网 |
ASP教程网 | ASP.NET教程网 | CorelDraw教程网 |