background image

CSS 网页布局开发时的常见问题小结,在进行 CSS 网页布局开发时,您肯定遇到过形形色色的布局问题。本文的目
的是让您的设计过程更为容易,当您遇到困难时为您提供快速参考。

一、避免

IE

 

下未指定样式内容的闪烁。

 

  如果您仅仅靠

@import 来输入外部样式表,早晚您会发现 IE

有 闪烁 的毛病。在应用

CSS 样式之前,未

经格式化的

HTML 文本会短暂地出现。这是可以避免的。

 

二、确保您期望的效果确实存在
  许多特定的浏览器专有的

CSS

 

 

扩展在正式标准中并不存在。 如果您对

filter(滤镜)或滚动条指定了样式,

那么您就用了私有代码,除了

IE 之外,在别的浏览器中毫无作用。如果验证器告诉您代码没有定义,极有可能您

用了私有样式,这样在不同的浏览器中很难达到一致的效果。
  如果布局中一定要用浮动对象,别忘了适时使用清除(

clear)属性。

  浮动对象似易实难,而且不总是令人如愿以偿。如果您发现浮动对象伸出了容器的边界,或者不像您所期望
的那样显示,请检查您的期望是否正确。关于这个问题请看

Eric Meyer 的教程

  边距的合并:可用

padding   

border 来避免。

 

  您可能被多余的(或者想要却不出现的)空白搞得焦头烂额。如果您用了

margins,边距的合并可能就是问

 

题的根源。

Andy Budd 对此的解释可能为你解惑。

 

  避免将

padding/border 和固定宽度同时应用到同一元素。

  

IE5 的区块模型是错误的,是它把事情办坏了。对此也有权宜之计,不过最好是绕过这个问题,当子元素的

宽度固定时,为父元素指定

padding。

 

三、有疑问,先验证
  在调试时,先对您的代码进行验证往往能省去不少麻烦事。格式不正确的

XHTML/CSS 会导致许多布局上的

错误。
  在其他浏览器中进行测试之前,请先在最先进的浏览器中撰写和测试

CSS 代码,而不是相反。

  如果您在破旧的浏览器中编写和测试,你的代码就不得不依赖那个破旧浏览器的糟糕的显示,然后在符合标

” 

准的浏览器中进行测试,看到显示结果 不正常 时,你会很沮丧的。相反,您应该先将您的代码完善,然后再设
法为较低级的浏览器打算。这样从一开始您的代码就是符合标准的,你不必再为支持其他浏览器而劳心费神。当

 

然了,目前遵从标准的浏览器无疑就是

Mozilla  

Safari   

Opera。

 

四、加上明显的边框有利于布局调试。

 

  像

div {border  

solid 1px #f00;} 之类的全局规则可以暂时为你查出布局问题。为特定的元素加上

边框可帮您找到难以发觉的交错或空白问题。
  对图片路径不要用单引号。
  当设置背景图片时,要坚持用双引号。尽管看起来有些多余,但是如果不这么做,

IE5/Mac 会噎住。

  不要为将来的样式表(比如手持式设备或打印用样式表)留个 空位 。
  

Mac IE5 对空的样式表比较感冒,会增加页面的装入时间。建议样式表中至少应该有一条规则(哪怕是注释

 

也好),免得

MacIE 噎住。

  另外值得一提的还有一些虽然不针对某些功能,但是在开发过程中应当注意的理论

五、好好组织您的

CSS

 

文件

  恰当地成块注释

CSS,将相似的 CSS 选择符编为一组,养成一致的命名习惯和空白格式(为跨平台考虑,建

议用空白字符而不是

tab。)以及适当的次序。

  以功能(而不是外观)为类和

ID 命名

 

  假如您创建了一个

.smallblue 类,后来打算将文字改大,颜色变为红色,这个类名就不再有任何意义了。

 

相反,您可以用更有描述性的名字如

.copyright   

.pullquote。

六、组合选择符
  保持

CSS

 

短小对减少下载时间非常重要。请尽量为选择符分组、 利用继承(

inheritance)以及使用简写

shorthand)来减少冗余。

  使用图片替换技术时要考虑亲和力
  已经发现传统的

FIR

 

在屏幕阅读器,以及关闭图片显示[的浏览器]中会出问题。 对此有其他解决办法,要

 

根据具体情况,慎重使用。

 

七、别指望

min-width 在 IE

 

中有用。

  

IE

 

不支持它,但是它将

width 

 

当作

min-width

 

,所以通过一些

IE 的过滤技巧(filtering),可以实

现同样的最终效果。
  把

CSS 过滤器(filters)当作最后的手段