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)当作最后的手段