跨浏览器的 inline-block 实现[CSS]

2016-02-19 19:48 4 1 收藏

下面图老师小编跟大家分享一个简单易学的跨浏览器的 inline-block 实现[CSS]教程,get新技能是需要行动的,喜欢的朋友赶紧收藏起来学习下吧!

【 tulaoshi.com - Web开发 】

  最近在为自己做个新站,想到了些效果,实现时碰到了些小麻烦,比如这个 inline block。所幸大多数问题都解决了,所以写出来分享一下。

  我们在制作网页时,有时会希望一个元素既能像 block 一样定义宽度和高度,又可以像普通的 inline 一样不断行。例如下面这张图片中红线标出的地方:

  通常我们实现这样的效果会使用这样的代码:

a href=”#”img src=”….” alt=”….” //a

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

这样虽然可以达到目的,但相对来说代码还是不够精炼,也不够灵活。而理想的方式,我们仅通过下面的代码即可实现:

a href=”#”Yangliu.name/a

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

  这样一来,我们就需要对 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。

来源:http://www.tulaoshi.com/n/20160219/1621840.html

延伸阅读
标签: Web开发
虽然22333.com向大家介绍了很多CSS属性的相关知识,但有些非常冷门的属性还是有所欠缺。在B/S程序中,对打印页面的控制,CSS相对比较弱,例如: 自动分页, 就基本没啥实际用途。我们通常需要自己在需要的时候,强制浏览器分页,这时可以使用以下样式: style type="text/css" .22333com { page-break-after:always;} /style auto :...
标签: Web开发
你是否为CSS3中那些形如-moz-border-radius这样冗长的前缀而头晕呢?你是否在考虑跨浏览器使用CSS3的时候,要记住哪些前缀是支持哪个浏览器的?你是否想过有什么办法能一劳永逸的(或者便捷的)解决这些问题? 不用发愁了,Paul Irish与朋友制作了一个有意思的CSS3生成器,在这个页面上你可以实时的编辑CSS3样式,并且立即可以看到效果...
java.applet包的AppletContext类包含如下两个成员方法:getApplet和getApplets。使用这两个方法,Applet能够寻找到其他的Applet并调用它们的方法。不过这是以满足如下安全条件为前提的: 所有Applet位于同一服务器的同一目录。 所有Applet运行在同一页面且位于同一浏览器窗口内。 或许为Applet加上这些安全限制都有着很充分...
标签: Web开发
块元素(block element)一般是其他元素的容器元素,块元素一般都从新行开始,它可以容纳内联元素和其他块元素,常见块元素是段落标签’P”。“form”这个块元素比较非凡,它只能用来容纳其他块元素。 假如没有css的作用,块元素会顺序以每次另起一行的方式一直往下排。而有了css以后,我们可以改变这种html的默认布局模式,把块元素摆放到你想要...
标签: Web开发
很多人认为,完美的跨浏览器兼容并不必要,这样说虽然没错,但在很多情形,一种近似的兼容还是很容易实现的,本文讲的是各种跨浏览器兼容的 CSS 编码准则和技巧。 作为 Web 设计师,你的网站在各种浏览器中有完全一样的表现是很多人的目标,然而这是一个永远无法真正实现的目标,很多人认为,完美的跨浏览器兼容并不必要,这样说虽然没错,但...

经验教程

953

收藏

23
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部