跨浏览器的 inline-block 实现[CSS]
2009-07-16 11:46
435 查看
from:http://blog.istef.info/2008/10/13/cross-browser-inline-block-css/
最近在为自己做个新站,想到了些效果,实现时碰到了些小麻烦,比如这个 inline block。所幸大多数问题都解决了,所以写出来分享一下。
我们在制作网页时,有时会希望一个元素既能像 block 一样定义宽度和高度,又可以像普通的 inline 一样不断行。例如下面这张图片中红线标出的地方:
通常我们实现这样的效果会使用这样的代码:
<a href=”#”><img src=”….” alt=”….” /></a>
这样虽然可以达到目的,但相对来说代码还是不够精炼,也不够灵活。而理想的方式,我们仅通过下面的代码即可实现:
<a href=”#”>Yangliu.name</a>
这样一来,我们就需要对 a 标签指定 width height 和 background-image。但 a 标签默认的 display 属性是 inline,width、height 是无效的。而如果对 a 设置 display:block,虽然可以解决宽度高度的问题,但元素会自动断行,无法达到我们需要的效果。有没有什么方式可以实现类似 img 标签那样,既可以设定高度宽度,又不会自动断行呢?
答案是肯定的。在 Opera 和 Webkit 中支持一个 CSS2 的属性 display: inline-block。利用这个属性,在 Opera 下即可完全实现我们所需的效果,但在其它浏览器下就不行了。
display 属性另外还有一个不太常用的值 display: inline-table。利用这个值也可以完全实现我们所需的效果。这个属性被除了 IE 以外的所有浏览器正确支持,但是…… 呃,又是 IE。虽然在面对 CSS 的时候所有 Web Developer 都会恨之入骨,但放弃 IE 就等于放弃 70% 的用户,所以我们还是得找出其它的解决方案。
没辙了,只好 Google,结果还真给我找到了。在这篇文章中指出,如果你首先触发 IE 的 hasLayout,然后再设置它的 display: inline,这个元素将变为 inline-block! 这样一来,我们就可以利用 IE 这个不可理喻的特点,结合一些 CSS Hacks,给出兼容各种浏览器的 CSS 代码:
通过这样的代码就可以实现在各种浏览器中表现一致的 inline-block 了。不过这种方式有个小缺憾,就是无法通过 W3C CSS 验证。当然,要想通过验证也很简单,可以对除了 IE 之外的浏览器发出 inline-table 属性的样式表,对于 IE 单独发出一份 IE Only 的 CSS。
save
最近在为自己做个新站,想到了些效果,实现时碰到了些小麻烦,比如这个 inline block。所幸大多数问题都解决了,所以写出来分享一下。
我们在制作网页时,有时会希望一个元素既能像 block 一样定义宽度和高度,又可以像普通的 inline 一样不断行。例如下面这张图片中红线标出的地方:
通常我们实现这样的效果会使用这样的代码:
<a href=”#”><img src=”….” alt=”….” /></a>
这样虽然可以达到目的,但相对来说代码还是不够精炼,也不够灵活。而理想的方式,我们仅通过下面的代码即可实现:
<a href=”#”>Yangliu.name</a>
这样一来,我们就需要对 a 标签指定 width height 和 background-image。但 a 标签默认的 display 属性是 inline,width、height 是无效的。而如果对 a 设置 display:block,虽然可以解决宽度高度的问题,但元素会自动断行,无法达到我们需要的效果。有没有什么方式可以实现类似 img 标签那样,既可以设定高度宽度,又不会自动断行呢?
答案是肯定的。在 Opera 和 Webkit 中支持一个 CSS2 的属性 display: inline-block。利用这个属性,在 Opera 下即可完全实现我们所需的效果,但在其它浏览器下就不行了。
display 属性另外还有一个不太常用的值 display: inline-table。利用这个值也可以完全实现我们所需的效果。这个属性被除了 IE 以外的所有浏览器正确支持,但是…… 呃,又是 IE。虽然在面对 CSS 的时候所有 Web Developer 都会恨之入骨,但放弃 IE 就等于放弃 70% 的用户,所以我们还是得找出其它的解决方案。
没辙了,只好 Google,结果还真给我找到了。在这篇文章中指出,如果你首先触发 IE 的 hasLayout,然后再设置它的 display: inline,这个元素将变为 inline-block! 这样一来,我们就可以利用 IE 这个不可理喻的特点,结合一些 CSS Hacks,给出兼容各种浏览器的 CSS 代码:
.element-class { display: -moz-inline-stack; //Firefox only code display: inline-block; //some standard browsers zoom: 1; //IE only *display: inline; //Only IE know this code (CSS Hack) }
通过这样的代码就可以实现在各种浏览器中表现一致的 inline-block 了。不过这种方式有个小缺憾,就是无法通过 W3C CSS 验证。当然,要想通过验证也很简单,可以对除了 IE 之外的浏览器发出 inline-table 属性的样式表,对于 IE 单独发出一份 IE Only 的 CSS。
save
相关文章推荐
- CSS中跨浏览器的inline-block实现
- 跨浏览器的 inline-block 实现[CSS]
- 用inline-block实现两列布局,在手机浏览器上有兼容性问题
- css: inline, inline-block, inline-table 在不同浏览器上的比较( 测试元素为三个table并列 )
- inline-block属性跨浏览器实现
- 跨浏览器的 inline-block 实现
- 实现浏览器兼容版的inline-block显示
- 如何实现浏览器兼容版的inline-block显示
- css inline-block方式实现水平导航栏 解决空白问题
- js实现根据浏览器类型自动调用不同CSS文件[收藏]
- css如何去掉inline-block之间的空隙
- CSS display:inline|block|inline-block差异
- 【CSS】block,inline和inline-block细节对比
- CSS兼容实现各浏览器的透明度
- css属性-display:inline、block、inline-block的区别
- CSS实现跨浏览器的box-shadow盒阴影效果(2)
- CSS实现背景图尺寸不随浏览器缩放而变化的两种方法
- 你不知道的css中block与inline的区别(转)
- css inline-block与inline的理解
- 【css】—— inline-block 4px 和图片底部 2px bug