CSS实现样式布局

使用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在屏幕阅读器,以及关闭图片显示[的浏览器]中会出问题。对此有其余解决办法,要根据具体状况,慎重使用。

相关文章
相关标签/搜索