zoukankan      html  css  js  c++  java
  • 【css】浅谈 inlineblock

    如今有很多网站都用上了 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>
            <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>

    从上面的代码我们很难发现产生“空白间隙”的问题。其实这个问题是我们写代码的习惯所造成的。平时我们写代码,为了使代码看上去“层级分明”,通常会在标签结束符后顺手打个回车,而回车会产生回车符,回车符相当于空白符,通常情况下,多个连续的空白符会合并成一个空白符,而产生“空白间隙”的真正原因就是这个让我们并不怎么注意的空白符。

    既然我们已经知道产生问题的原因了,那么就很好解决该问题。空白符也是字符,只要是字符就会联想到字体,字体大小之类的。所以去除空白符的存在只需要设置字体大小为零就行了(font-size:0;)。修改已上代码:

    <!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">
        ul{
            font-size:0;
        }
        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,firefox,chrome 和 opera 浏览器下已经没有问题了,但是在 safari 浏览器下还是有问题。

    关于 safari 浏览器的兼容,请阅读大漠写的《如何解决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">
        ul{
            font-size:0;
            letter-spacing: -8px;/*根据不同字体字号或许需要做一定的调整*/
            word-spacing: -8px;
        }
        li{
            display:inline-block;
            *display:inline;
            *zoom:1;
            letter-spacing:normal;
            word-spacing:normal;
        }
        </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>

    兼容浏览器:ie6,ie7,ie8,chrome,firefox,safari,opera。

  • 相关阅读:
    死工资的缓慢呆板已不能适合这个新型的商业社会。
    java获取前一天时间SimpleDateFormat,java判断某个时间段
    设置 DNS,防止 DNS 污染,清除 DNS 缓存ipconfig /flushdns
    win7 怎么设置开机直接进入桌面? netplwiz 命令
    AWS免费云服务套餐申请步骤及常见问题
    阿里云自定义镜像可以免费保存,ECS实例到期后自定义镜像手动快照不会被删除
    php获取字符串长度函数strlen和mb_strlen
    PHP HTML混写,PHP中把大块HTML文本直接赋值给字符串变量的方法
    人工智能跟脑神经科学没有关系。没有出差错的机会,就没有进化的可能。要想自己把事情做成功,就需要弄清楚事物的本质。
    python GIL 全局锁,多核cpu下的多线程性能究竟如何?
  • 原文地址:https://www.cnblogs.com/yjzhu/p/2975272.html
Copyright © 2011-2022 走看看