CSS的inline-block属性分析

解决浮动的蹊跷问题
服务器君一共花费了225.297 ms进行了5次数据库查询,努力地为您提供了这个页面。
试试阅读模式?希望听取您的建议

ie6,ie7的haslayout属性是个让人头疼的问题。在做导航条的时候,一般会用到ul li结构,大多数时候我们是把li设置为浮动,让其并排显示在同一行。还有一种方法就是设置li为display:inline;这样可以达到同样的效果,但是问题是inline元素的特性:默认无法设置宽度,高度,以及上下margin,(关于padding,情况有点特殊,在ie6,7中inline元素是无法设置上下padding的,但是在标准浏览器里面是可以设置上下padding的)。

鉴于inline元素的这种特性,如果我们不浮动并且想让li显示在一行,而且可以设置高度,宽度以及上下margin,上下padding等属性,应该怎么办呢?你一定会想到一个属性display:inline-block;对!”inline-block”就是干这个事的,让一个元素既不换行又具有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;
	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>

上面的例子,在firefox,opera等标准浏览器里面已经达到效果了,但是在ie6和ie7下却发现每个li元素仍然独占一行,(关于margin合并的问题日后再说)。这是因为ie6和ie7并不完全支持inline-block这个属性值。通过上面的例子会发现加不加display:inline-block;对于它们完全没有任何影响。

那么让我们来想办法解决这个问题,这就涉及到ie6,7中的haslayout属性了。ie6,7中的inline元素有个特殊的情况,就是触发了ie的hasLayout属性以后就拥有了layout。此时inline元素的表现和标准浏览器里面的inline-block元素基本相同。看下面这个例子,我们用ie的私有属性zoom来触发hasLayout,然后看看inline元素的表现。

<!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代码中的

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的表现。

本文地址:http://www.nowamagic.net/librarys/veda/detail/708,欢迎访问原出处。

不打个分吗?

转载随意,但请带上本文地址:

http://www.nowamagic.net/librarys/veda/detail/708

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能。
小提示:您可以按快捷键 Ctrl + D,或点此 加入收藏

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢,学习效率低,我觉得一个重要原因是看的书少了。多少是多呢?起码得看3、4、5、6米吧。给个具体的数量,那就100本书吧。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么,我们可以让他坐“上位”毕竟他是面试官,但是在知识结构体系以及心理上我们就居高临下。

所以,阅读一百本计算机著作吧,少年!

《大话设计模式》 程杰 (作者)

《大话设计模式》通篇都是以情景对话的形式,用多个小故事或编程示例来组织讲解GoF(设计模式的经典名著——Design Patterns: Elements of Reusable Object-Oriented Software,中译本名为《设计模式——可复用面向对象软件的基础》的四位作者Erich Gamma、Richard Helm、Ralph Johnson,以及JohnVlissides,这四人常被称为GangofFour,即四人组,简称GoF)总结的23个设计模式。本书共分为29章。其中,第1、3、4、5章着重讲解了面向对象的意义、好处以及几个重要的设计原则;第2章,以及第6到第28章详细讲解了23个设计模式;第29章是对设计模式的全面总结。

更多计算机宝库...