模拟兼容性的 inline-block 属性
程序员文章站
2023-11-03 12:53:03
而现在对于 inline-block 属性运用的需求也越来越多,可惜依旧只有 firefox3 beta、ie8 beta...
而现在对于 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; 来解决。
最终我们模拟的代码如下:
display:inline-block; /*firefox3 beta、ie8 beta、opera、safari 支持,ie 下触发 inline 元素的 haslayout*/
display:-moz-inline-stack; /* firefox 的私有属性,也可以用 -moz-inline-box */
zoom:1; /*ie 下触发 haslayout*/
*display:inline; /*一旦ie 下触发了 haslayout,设置 block 元素为 inline 会使 display:inline 效果与 display:inline-block 相似*/
text-indent:-9999px;
*text-indent:0;
font-size:0;
line-height:0; /* 如需隐藏文字,可用这四个属性 */
/*另外上面隐藏文字,还可以用更简化的方法:line-height:超级大值;font-size:0; */
overflow:hidden; /* 隐藏溢出的内容 */
vertical-align:middle; /* 行内垂直居中,针对 opera 比较大的偏离 */
width:?px; /*?为任意非auto值*/
height:?px; /*?为任意非auto值*/
在实际应用中 -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; 来解决。
最终我们模拟的代码如下:
复制代码 代码如下:
display:inline-block; /*firefox3 beta、ie8 beta、opera、safari 支持,ie 下触发 inline 元素的 haslayout*/
display:-moz-inline-stack; /* firefox 的私有属性,也可以用 -moz-inline-box */
zoom:1; /*ie 下触发 haslayout*/
*display:inline; /*一旦ie 下触发了 haslayout,设置 block 元素为 inline 会使 display:inline 效果与 display:inline-block 相似*/
text-indent:-9999px;
*text-indent:0;
font-size:0;
line-height:0; /* 如需隐藏文字,可用这四个属性 */
/*另外上面隐藏文字,还可以用更简化的方法:line-height:超级大值;font-size:0; */
overflow:hidden; /* 隐藏溢出的内容 */
vertical-align:middle; /* 行内垂直居中,针对 opera 比较大的偏离 */
width:?px; /*?为任意非auto值*/
height:?px; /*?为任意非auto值*/
上一篇: 自定义标签实现圆角边框
推荐阅读
-
模拟兼容性的 inline-block 属性
-
浏览器兼容性问题——IE不支持却很实用的CSS属性(一)
-
(转)Android模拟器的属性配置介绍
-
(转)Android模拟器的属性配置介绍
-
模拟反编译,输出一个类的属性及方法
-
模拟兼容性的 inline-block 属性
-
javaScript 利用闭包模拟对象的私有属性_javascript技巧
-
CSS中display属性:block、inline和inline-block的区别_html/css_WEB-ITnose
-
兼容性的 inline-block 属性_HTML/Xhtml_网页制作
-
解决inline-block属性带来的标签间间隙问题_html/css_WEB-ITnose