浅谈inline-block及解决空白间距

2020-05-12 11:03:06易采站长站整理

复制代码
宋体/Verdana -.5em
Arial -.25em
Tahoma -.333em

方法2未经实验,备忘!

如今有很多网站都用上了 inline-block 属性,比如 {display:inline-block; *display:inline; *zoom:1},以上 css 代码随处可见。很多人看见 *display:inline; *zoom:1 就下意识的认为:哦,原来 inline-block 这个属性 ie6 和 ie7 不支持。那么 ie6,7 真的不支持 display:inline-block 吗?

事实上,ie 从 5.5 开始就已经支持 display:inline-block 了,只是支持的并不是那么完美。具体的请阅读淘宝UED官方博客——一丝所写的《display:inline-block 前世今生》。

当我们使用 inline-block 的时候,就会产生“空白间隙”问题。代码如下:

复制代码
<!DOCTYPE HTML>
<html lang=”en-US”>
<head>
<meta charset=”UTF-8″/>
<title>inline-block</title>
<link rel=”stylesheet” type=”text/css” href=”css/base.css” media=”all”/>
<style type=”text/css”>
li{
display:inline-block;
*display:inline;
*zoom:1;
}
</style>
</head>
<body>
<ul>
<li><img src=”images/cat.jpg” alt=”” width=”248″ height=”162″/></li>
<li><img src=”images/cat.jpg” alt=”” width=”248″ height=”162″/></li>
<li><img src=”images/cat.jpg” alt=”” width=”248″ height=”162″/></li>
</ul>
</body>
</html>

效果图如下:

我们可以看到:在 ie8、chrome、firefox、opera 以及 safari 浏览器下,两张图片之间有“空白间隙”。

但是在 ie6 和 ie7 浏览器下却正常显示,效果如下:

下面我们就来说说这个“空白间隙”是如何产生的,以及解决办法。

先来说说“空白间隙”是怎么产生的?先看下源代码:

复制代码
<!DOCTYPE HTML>
<html lang=”en-US”>
<head>
<meta charset=”UTF-8″/>
<title>inline-block</title>
<link rel=”stylesheet” type=”text/css” href=”css/base.css” media=”all”/>
<style type=”text/css”>
li{
display:inline-block;
*display:inline;
*zoom:1;
}
</style>
</head>
<body>
<ul>
<li><img src=”images/cat.jpg” alt=”” width=”248″ height=”162″/></li>