找回密码
 注册

QQ登录

只需一步,快速开始

查看: 3366|回复: 4

[教程] 模拟兼容性的 inline-block 属性

[复制链接]
发表于 2008-5-26 21:49:32 | 显示全部楼层 |阅读模式
一年前网上还找不到关于 inline-block 属性的文章,为了方便大家更好的理解该属性,当时总结整理了篇《display:inline-block的深入理解》

而现在对于 inline-block 属性运用的需求也越来越多,可惜依旧只有 Firefox3 beta、IE8 beta、Opera、Safari 支持 inline-block 属性(注:原来只有 Opera、Safari 支持),但 IE6、IE7 可以通过触发 hasLayout 来模拟,Firefox2 有-moz-inline-box 和 -moz-inline-stack 私有属性(这两个属性的比较引用自秦歌的《display:inline-block的应用两例》)。

在实际应用中 -moz-inline-box 会存在元素间的对齐等问题,虽然 Firefox 还有一个私有属性 -moz-box-align 来帮助解决对齐问题,但依旧难以预料问题多多,而相对来说 -moz-inline-stack 的表现更像 inline-block ,这点可以在 Firefox3 中测试出来。但 -moz-inline-stack 使用时也会有一个 bug ,如果一个 display:-moz-inline-stack; 的元素外层元素是 display:inline; 即会使 Firefox 中其包含的链接不可点,这个需要用 position:relative; 来解决。


最终我们模拟的代码如下:

  1. display:inline-block; /*Firefox3 beta、IE8 beta、Opera、Safari 支持,IE 下触发 inline 元素的 hasLayout*/
  2. display:-moz-inline-stack; /* Firefox 的私有属性,也可以用 -moz-inline-box */

  3. zoom:1; /*IE 下触发 hasLayout*/
  4. *display:inline; /*一旦IE 下触发了 hasLayout,设置 block 元素为 inline 会使 display:inline 效果与 display:inline-block 相似*/

  5. text-indent:-9999px;
  6. *text-indent:0;
  7. font-size:0;
  8. line-height:0; /* 如需隐藏文字,可用这四个属性 */
  9. /*另外上面隐藏文字,还可以用更简化的方法:line-height:超级大值;font-size:0; */

  10. overflow:hidden; /* 隐藏溢出的内容 */

  11. vertical-align:middle; /* 行内垂直居中,针对 Opera 比较大的偏离 */

  12. width:?px; /*?为任意非auto值*/
  13. height:?px; /*?为任意非auto值*/
复制代码


扩展阅读:

评分

参与人数 1威望 +2 收起 理由
phantom + 2 谢谢分享好东西

查看全部评分

发表于 2008-5-26 22:12:15 | 显示全部楼层
很好,今天看YUI的样式有这方面的内容。

又让我少了用浮动的机会,也不用不好搞就用浮动了
回复 支持 反对

使用道具 举报

发表于 2008-5-26 22:42:06 | 显示全部楼层
拜读了...找个属性最近很少看到好文章...
回复 支持 反对

使用道具 举报

发表于 2008-5-26 23:35:32 | 显示全部楼层
恩,很不错。。  浏览器兼容。。。真是件让人费心的事。。
回复 支持 反对

使用道具 举报

发表于 2008-5-27 10:13:05 | 显示全部楼层
A标签使用display:-moz-inline-stack,其里面图片属性dislpay为block时,还会发生一个有趣的现象
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|Archiver|手机版|blueidea.com ( 湘ICP备12001430号 )

GMT+8, 2021-1-19 20:21 , Processed in 0.061150 second(s), 14 queries , Gzip On, Memcache On.

Powered by Discuz! X3.2 Licensed

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表