二月 20th, 2009CSS兼容问题:inline-block 属性运用

Html/Css/PsKelvin8:26

现在对于 inline-block 属性运用的需求也越来越多,可惜依旧只有 Firefox3 beta、IE8 beta、Opera、Safari 支持 inline-block 属性(注:原来只有 Opera、Safari 支持),但 IE6、IE7 可以通过触发 hasLayout 来模拟,Firefox2 有-moz-inline-box 和 -moz-inline-stack 私有属性。

在实际应用中 -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 betaIE8 betaOperaSafari 支持,IE 下触发 inline 元素的 hasLayout*/
  2. display:-moz-inline-stack; /* Firefox 的私有属性,也可以用 -moz-inline-box */
  3.  
  4. zoom:1; /*IE 下触发 hasLayout*/
  5. *display:inline; /*一旦IE 下触发了 hasLayout,设置 block 元素为 inline 会使 display:inline 效果与display:inline-block 相似*/
  6.  
  7. text-indent:-9999px;
  8. *text-indent:0;
  9. font-size:0;
  10. line-height:0; /* 如需隐藏文字,可用这四个属性 */
  11. /*另外上面隐藏文字,还可以用更简化的方法:line-height:超级大值;font-size:0; */
  12.  
  13. overflow:hidden; /* 隐藏溢出的内容 */
  14.  
  15. vertical-align:middle; /* 行内垂直居中,针对 Opera 比较大的偏离 */
  16.  
  17. width:?px; /*?为任意非auto*/
  18. height:?px; /*?为任意非auto*/

本站遵循 署名-非商业性使用-相同方式共享 3.0 共享协议,转载请注明作者及出处。

Del.icio.us Google书签 Digg Live Bookmark Technorati Furl Yahoo书签 Facebook 百度搜藏 新浪ViVi 365Key网摘 天极网摘 和讯网摘 博拉网 POCO网摘 添加到饭否 QQ书签 Digbuzz我挖网

要说点啥就在这吧