通百艺而专一长
In: Web设计
15 七 2009一、 针对浏览器的选择器
这些选择器在你需要针对某款浏览器进行css设计时将非常有用.
* html {}
IE7及其更低版本
*:first-child+html {} * html {}
仅针对IE7
*:first-child+html {}
IE7和当代浏览器
html>body{}
仅当代浏览器(IE7不适用)
html>/**/body{}
Opera9及其更低版本
html:first-child {}
Safari
html[xmlns*=""] body:last-child {}
要使用这些选择器,请将它们放在样式之前. 例如:
您也可以参考—CSS hacks:浏览器特定选择器介绍
http://www.52css.com/article.asp?id=635
二、让IE6支持PNG透明
一个IE6的Bug引起了大麻烦, 他不支持透明的PNG图片。
你需要使用一个css滤镜.52css.com]
您也可以参考—除链接元素的虚线框(兼容IE7、IE6、FF)
http://www.52css.com/article.asp?id=743
四、给行内元素定义宽度
如果你给一个行内元素定义宽度,那么它只是在IE6下有效. 所有的HTML元素要么是行内元素要么就好是块元素. 行内元素包括: <span>, <a>, <strong> 和 <em>. 块元素包括<div>, <p>, <h1>, <form>和<li> . 你不能定义行内元素的宽度, 为了解决这个问题你可以将行内元素转变为块元素.
五、让固定宽度的页面居中
为了让页面在浏览器居中显示, 需要相对定位外层div, 然后把margin设置为auto. [www.52css.com]
六、IE6双倍边距的bug
给此对象加上display:inline即可解决问题。具体介绍:
http://www.52css.com/article.asp?id=144
七、Box Model 盒模型bug的一般解决办法
这是一个臭名昭著的问题了,详情参考这里:
http://www.52css.com/article.asp?id=106
八、两个层之间的3px间隙
传说中的“IE 3px bug”,解决的办法:
http://www.52css.com/article.asp?id=146
九、在IE中的HTML注释引起文字奇怪的复制
Duplicate Characters Bug很神奇,具体的解决办法:
http://www.52css.com/article.asp?id=440
十、图片替换技术
用文字总比用图片做标题好一些. 文字对屏幕阅读机和SEO都是非常友好的.
<h1><span>Main heading one</span></h1>
CSS:
h1 { background: url(heading-image.gif) no-repeat; }
h1 span {
position:absolute;
text-indent: -5000px;
} 你可以看到我们对标题使用了标准的<h1>作为标签并且用css来将文本替换为图片. text-indent属性将文字推到了浏览器左边5000px处, 这样对于浏览者来说就看不见了.
十一、 最小宽度
IE6另外一个bug就是它不支持 min-width 属性. min-width又是相当有用的, 特别是对于弹性模板来说, 它们有一个100%的宽度,min-width 可以告诉浏览器何时就不要再压缩宽度了.
除IE6以外所有的浏览器你只需要一个 min-width: Xpx; 例如:.52css.com]
为了让他在IE6下工作, 我们需要一些额外的工作. 开始的时候我们需要创建两个div, 一个包含另一个:.52css.com]
然后你需要定义外层div的min-width属性,本文由52CSS.com整理,转载请注明出处!.52css.com]
十二、隐藏水平滚动条
为了避免出现水平滚动条, 在body里加入 overflow-x:hidden .
当你决定使用一个比浏览器窗口大的图片或者flash时, 这个技巧将非常有用.