使用CSS建站时,您确定遇到过形形色色的布局问题,最后可能被搞得焦头烂额。本文的目的是让您的设计过程更为容易,当您遇到困难时为您提供快速参考。浏览器
一、有疑问,先验证缓存
在调试时,先对您的代码进行验证每每能省去很多麻烦事。格式不正确的XHTML/CSS 会致使许多布局上的错误。在其余浏览器中进行测试以前,请先在最早进的浏览器中撰写和测试CSS代码,而不是相反。布局
若是您在破旧的浏览器中编写和测试,你的代码就不得不依赖那个破旧浏览器的糟糕的显示,而后在符合标准的浏览器中进行测试,看到显示结果“不正常” 时,你会很沮丧的。相反,您应该先将您的代码完善,而后再设法为较低级的浏览器打算。这样从一开始您的代码就是符合标准的,你没必要再为支持其余浏览器而劳 心费神。固然了,目前听从标准的浏览器无疑就是 Mozilla, Safari 或 Opera。测试
二、确保您想要的效果然的存在字体
许多特定的浏览器专有的CSS扩展在正式标准中并不存在。 若是您对 filter(滤镜) 或滚动条指定样式,您用的就是私有代码,除了IE以外,在别的浏览器中毫无做用。若是验证器告诉您代码没有定义,极有可能您用了私有样式,别期望在不一样的浏览器中获得一致的效果。设计
三、若是布局中必定要用浮动对象,别忘了适时使用清除(clear)属性调试
浮动元素似易实难,并且难以驾驭。若是您发现浮动对象伸出了容器的边界,或者不像您所指望的那样显示,请检查您的指望是否正确。关于这个问题请看Eric Meyer 的教程orm
四、边距的合并:可用padding 或 border 来避免对象
您可能被多余的(或者想要却不出现的)空白搞得焦头烂额。若是您用了 margins,边距的合并可能就是问题的根源。 Andy Budd 对此的解释也许能为你解惑。继承
五、避免将 padding/border 和固定宽度同时应用到同一元素
IE5 错误的区块模型是罪魁祸首,是它把事情弄得乱七八糟。虽然有补救方案,不过最好是绕过这个问题,当子元素的宽度固定时,为其父元素指定padding。
六、避免IE下未指定样式内容的闪烁
若是您用 @import 来输入外部样式表,迟早会发现IE有“闪烁”的毛病。在应用CSS样式以前,未格式化的HTML文本会短暂地出现。这是能够避免的.
七、别期望 min-width 在IE中有用
IE不支持它,可是它将 width 看成 min-width,因此经过一些 IE 的过滤技巧(filtering),能够实现一样的最终效果。
八、走投无路时,试一试减小宽度
因为舍入偏差,有时 50% 加上 50% 等于 100.1%,破坏某些浏览器中的布局。不妨试试将 50% 减到 49%,甚至 49.9%。
九、IE 中显示不正常
多是 Peekaboo 臭虫在做怪,尤为是当鼠标通过超连接时能显示正常。修补方法见Position is Everything。
十、若是使用了锚点,在应用超连接样式时要特别当心
若是您在代码中使用了传统的锚点(),您会注意到 :hover 和 :active伪类也会做用于它。要避免这种情形,你可使用 id,或者使用不为人知的语法: :link:hover, :link:active
十一、记住“LoVe/HAte”(爱/恨)连接规则
要如下面的顺序指定超连接伪类:Link, Visited, Hover, Acitve。任何其余顺序都不稳当。假如用了 :focus,次序应为 LVHFA(“Lord Vader's Handle Formerly Anakin”,Matt Haughey这样建议)。
十二、请记住“TRouBLED”(麻烦的)边框
边框(border)、边距(margin)和补白(padding)的简写次序为:顺时针方向从上开始,即 Top, Right, Bottom, Left。好比 margin: 0 1px 3px 5px;表示上边距为零,右边距为1px,依此类推。
1三、非零值要指明单位
在用CSS指定字体、边距或大小时,必须指明所用的单位(惟一的例外是 line-height,很奇怪,它不须要单位)。某些浏览器对未指明单位的处理方法不足为据。零就是零,无论是 px 仍是 em。其余的非零值都要明确指定单位。例如: padding: 0 2px 0 1em;
1四、测试不一样的字体大小
像 Mozilla 和 Opera 这样的高级浏览器都容许你改变字体大小,无论你用什么字体单位。某些用户的默认字体大小确定和你的不一样,尽最大努力去知足他们。
1五、测试时用嵌入式样式,发布时再改成外部输入
将样式表嵌入在你的 HTML 源代码中,在测试时能够消除许多缓存引发的错误,尤为是某些 Mac 下的浏览器。但在发布前,必定要记住将样式表移到外部文件,用 @import 或 引入。
1六、加上明显的边框有助于布局调试
像 div {border: solid 1px #f00;} 之类的全局规则能够暂时为你查出布局问题。为特定的元素加上边框可帮您找到难以发觉的重叠或空白问题。
1七、图片路径不要用单引号
当设置背景图片时,要坚持用双引号。尽管看起来好像画蛇添足,可是若是不这么作,IE5/Mac 会噎住。
1八、不要为未来的样式表(好比手持式设备或打印用样式表)“占位子”
Mac IE5 对空的样式表比较感冒,会增长页面的装入时间。建议样式表中至少应该有一条规则(哪怕是注释也好),省得 MacIE噎住。
还有一些建议虽然不针对某些功能,可是在开发过程当中值得注意:
1九、好好组织您的CSS文件
恰当地成块注释CSS,将类似的CSS选择符编为一组,养成一致的命名习惯和空白格式(为跨平台考虑,建议用空白字符而不是tab。)以及适当的次序。
20、以功能(而不是外观)为类和ID命名
假如您建立了一个 .smallblue 类,后来打算将文字改大,颜色变为红色,这个类名就再也不有任何意义了。相反,您能够用更有描述性的名字如 .copyright 和 .pullquote。
2一、组合选择符
保持CSS短小对减小下载时间很是重要。请尽可能为选择符分组、利用继承(inheritance)以及使用简写(shorthand)来减小冗余。
2二、使用图片替换技术时要考虑亲和力
已经发现传统的FIR在屏幕阅读器,以及关闭图片显示[的浏览器]中会出问题。对此有其余解决办法,要根据具体状况,慎重使用。