css 锦囊
最后更新:4 feb 2004
翻译:onestab [2004.02.08]
出自:onestab.net
原文:mezzoblue css crib sheet
在使用css建站时,您肯定遇到过形形色色的布局问题,最后可能被搞得焦头烂额。本文的目的是让您的设计过程更为容易,当您遇到困难时为您提供快速参考。
如果您有所补充,请在这里发表您的意见.
本文的其他语言版:法语, 德语, 西班牙语 和 匈牙利语。 欢迎提供其他翻译。
- 有疑问,先验证
- 在调试时,先对您的代码进行验证往往能省去不少麻烦事。格式不正确的xhtml/css 会导致许多布局上的错误。
- 在其他浏览器中进行测试之前,请先在最先进的浏览器中撰写和测试css代码,而不是相反。
- 如果您在破旧的浏览器中编写和测试,你的代码就不得不依赖那个破旧浏览器的糟糕的显示,然后在符合标准的浏览器中进行测试,看到显示结果“不正常”时,你会很沮丧的。相反,您应该先将您的代码完善,然后再设法为较低级的浏览器打算。这样从一开始您的代码就是符合标准的,你不必再为支持其他浏览器而劳心费神。当然,现在支持标准的浏览器当然是 mozilla, safari 或 opera。
- 确保您期望的效果确实存在
- 许多特定的浏览器专有的css扩展在正式标准中并不存在。 如果您对
filter(滤镜)或滚动条指定了样式,那么您就用了私有代码,除了ie之外,在别的浏览器中毫无作用。如果验证器告诉您代码没有定义,极有可能您用了私有样式,在不同的浏览器中很难达到一致的效果。 - 如果布局中一定要用浮动对象,别忘了适时使用清除(clear)属性。
- 浮动对象似易实难,而且不总是令人如愿以偿。如果您发现浮动对象伸出了容器的边界,或者不像您所期望的那样显示,请检查您的期望是否正确。关于这个问题请看eric meyer的教程
- 边距的合并:可用padding 或 border 来避免。
- 您可能被多余的(或者想要却不出现的)空白搞得焦头烂额。如果您用了 margins,边距的合并可能就是问题的根源。 andy budd 对此的解释可能为你解惑。
- 避免将 padding/border 和固定宽度同时应用到同一元素。
- ie5 的区块模型是错误的,是它把事情办坏了。对此也有权宜之计,不过最好是绕过这个问题,当子元素的宽度固定时,为父元素指定padding。
- 避免ie下未指定样式内容的闪烁。
- 如果您仅仅靠
@import来输入外部样式表,早晚您会发现ie有“闪烁”的毛病。在应用css样式之前,未经格式化的html文本会短暂地出现。这是可以避免的. - 别指望
min-width在ie中有用。 - ie不支持它,但是它将
width当作min-width,所以通过一些 ie 的过滤技巧(filtering),可以实现同样的最终效果。 - 把css过滤器(filters)当作最后的手段
- css 技巧和过滤器可以使您有选择地应用到(或者不应用到)某些元素。应当尽可能地找到标准的跨浏览器的解决办法来实现您想要的效果,而不是动不动就使用过滤器。要将它当成走投无路时的救命手段。在这里可以找到大量的css 过滤技巧。[译注:不要把这里的filters和ie中的滤镜混淆。由于各个浏览器对css标准的支持程度不一,人们找到了许多技巧,将浏览器无法解释或错误解释的样式表或规则屏蔽掉。这就是所谓的css过滤器或技巧。]
- 如果使用了锚点,在应用超链接样式时要特别小心。
- 如果您在代码中使用了传统的锚点(
<a name="anchor">),您会注意到: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,依此类推。 - 非零值要指明单位。
- 在用css指定字体、边距或大小时,必须指明所用的单位。某些浏览器对未指明单位的处理方法不足为凭。零就是零,不管是 px还是em还是其他单位,它不需要单位。例如:
padding: 0 2px 0 1em; - 测试不同的字体大小。
- 像mozilla和opera这样的高级浏览器允许对字体进行缩放,不管你用的是什么单位。某些用户的默认字体大小肯定和您的不同,尽最大努力去满足他们。
- 用嵌入式测试,发布时改为输入。
- 将样式表嵌入在你的html源代码中,在测试时可以消除许多缓存引起的错误,尤其是某些mac下的浏览器。但在发布前,一定要记住将样式表移到外部文件,用