网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网页制作 > CSS
网页制作:Dreamweaver教程,FrontPages教程,Javascript教程,HTML教程,CSS教程,心得技巧,DHTML教程,网页特效,Discuz!论坛
本月文章推荐
.网页风格化 用CSS实现皮肤适时切.
.用CSS来控制网页背景.
.网页布局中CSS的Class灵活应用.
.CSS技巧DIV为空时占据空间的解决.
.基于XHTML的DIV+CSS网页制作布局.
.拒绝单调 让网页超链接拥有多姿多.
.网页切图、css命名规则.
.跟初学者分享:学习css需要什么软.
.学习CSS的背景图像属性background.
.最近做切割发现的css,float兼容问.
.对display:inline;与float:left;.
.用相对定位和负向移动完成图片象.
.CSS实现未知高度图文混合垂直居中.
.用CSS写的星级评分.
.CSS的渲染效率-书写高效的CSS.
.用css让图片自动适应大小.
.IE对网页中引入CSS样式表的限制.
.想让DIV居中 如何编写CSS .
.CSS扩展滤镜属性及语法.
.CSS中权重的例子.

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

发表日期:2008-10-14


最近在为自己做个新站,想到了些效果,实现时碰到了些小麻烦,比如这个 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。

上一篇:CSS中的Position属性 人气:1399
下一篇:DIV+CSS与XHTML+CSS是什么意思? 人气:1295
浏览全部CSS的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐