原文连接在这里 ,主要介绍原作者的针对 Explorer6 调试 CSS 的一些经验。不过在我个人看来,这也是一般性的 CSS 调试方法。
防患于未然
坦白的讲,我每天都会话很多时间用于调试 Explorer6 的 CSS 问题上。下面是一些小 Tips 可以确保 Explorer6 最大限度的返回你期望的效果。不幸的是,并不是每个人都知道它们(译注:作者有些「危言耸听」)。
重置默认样式
重置默认样式可以最大限度的避免浏览器差异,最简单的样式重置通常可以这样写
* {
margin: 0;
padding: 0;
}
如果你觉得这样「太过于简单」,可以参考 YUI Reset 和 Eric Meyer's Reset 。
不要在同一元素上同时声明 margin/padding 的宽度
由于 Explorer6 糟糕的 盒模型 ,你必须要万分小心。如果你需要将一元素设置了宽度,注意避免再将其上设定margin、padding(左边或者右边)。我会在其上再包裹一层元素,比如 <p>、<ul>、<table>、<hr>
这样的标签。
在大多数情况下,设计师会统一同一种元素的样式,比如段落的内间距(padding)统一为 8px 到 20px(通常为 10px)
p {
padding: 0 10px;
}
这是个非常好的定义。
另外:我一直使用像素(pixels)作为 margin 和 padding 的单位,因为如果使用 em,那么可能在使用不同的字体造成不同的宽度差异。
校验 XHTML、HTML
我已经好几次遇到这样的问题,在 Firefox 和 Safari 显示完好的页面,却在 Explorer6 下显得惨不忍睹。如果 Explorer7 也出现了这样的问题,那可能是遗失了「<
」或者「>
」之故。为了些可预见性的问题,其他浏览器都会注意这个问题,唯独 Explorer 。
我经常使用 Firefox 的 HTML validator 插件 验证页面代码。
保持清除浮动
总会有页面要将某个元素浮动起来,如果是定宽的那么还好办。如果是不定宽度的,那么要清除下浮动 -- 毕竟其他元素不一定都是浮动的。总之,时刻记得清除浮动是个好的习惯(译注: 也可以参看我以前的文章 )。
调试的技巧
虽然有多年针对 Explorer6 的 CSS 调试经验,一些常见的问题我知道如何去解决,但真的碰到很头痛的问题时,那时我通常会这样解决
- 打开电脑,载入 Explorer6 (译注:废话 -_-!)
- 确保安装了 IE Accessibility 工具条
- 点击工具条上的「编辑 CSS」
- 然后我开始「变魔术」
寻找错误
设定背景色
我经常会在指定的大块元素上设定个背景色
#content {
background-color: red;
}
#sidebar {
background-color:blue;
}
这能让我知道是哪块元素出了问题(译注:我喜欢用「red」高亮,因为好打而且显眼)。
隐藏元素
然后开始逐级的隐藏该块元素中的内容,首先是最大的块
#sidebar {
display: none;
}
如果问题消失了,那么再逐级在块中寻找出问题的元素,比如
#sidebar .sub-item {
display: none;
}
或者
#sidebar .sub-item .sub-sub-item {
display: none;
}
使用这一方法,通常就能精确的定位哪个元素造成的问题(按照经验通常是 <div>
或者是 <p>
)。
寻找解决方案
Explorer6 是头「烈马」,它会按照自己的规则去渲染 CSS 。当找到对应的元素后,下面有些经验式的解决方案可以参考一下(保持原作、顺便偷懒就不翻译了)
#sidebar .sub-item .sub-subitem {
/* try setting this if it’s not already set - it sometimes works wonders */
position: relative;
/* display: inline often fixes the double margin float bug and */
display: inline;
/* Sometimes this just fixes problems - no idea why */
display: inline-block;
/* margin can be a killer so take it off completely see if the problem goes away */
margin: 0;
/* same as margin */
padding: 0;
/* Sometimes IE6 hates background colours not being declared */
background-color: transparent;
/* can sometimes stop columns too wide from breaking a layout */
overflow: hidden;
/* Sometimes forces hasLayout and fixes things */
zoom: 1;
}
我经常会碰到改变它的 margin 和 display 就能解决问题。然后我会使用 Google 搜索网上是否有相应的 Bug 记录。
解决问题
当我找到解决该问题的办法以后,通常我会将其放到名为 ie6.css 文件中,然后只让 Explorer6 载入该 CSS 。当然,要确定该样式会覆盖原先定义的样式。
译注:当然也可以使用 CSS Hacks ,但不推荐这样做,原因之一是要「 保持 CSS 简单 」。
// 鲜果认领 BANGD5F9111B31CF304E38747370XIANGUO
我喜欢用“red”高亮,因为好打而且显眼
........
估计第二种颜色就是 blue 了.
@wiLdGoose 您答对了~
干吗喜欢叫 Explorer6 呢, 明明是 ie6 嘛, 就你这样叫...
草是谁?
调试时定义背景颜色和边框颜色是个好习惯,在IE下有个"万能"的haslayout可以出发。。。
另外我给的建议是颜色要用yellow,你知道什么叫yellow么。。。。
@Macji 还是 red 好打,才三个字母(我很懒)
@漫步 学 PPK 的叫法,顺便觉得这样更“正式”些
你好,我做了个Css背景图合并的工具,它
可以将多张小背景图合并为1张大图可以通过鼠标拖动自由移动小图的位置
生成大图和参考的css的html文件
可以设定生成文件的格式,
可以指定大图的背景色,默认为透明色
这个工具是开源的
具体请看
http://www.cnblogs.com/yukaizhao/archive/2008/12/15/css_background_image_merge_tool.html
如果好用,请推广一下这个工具,谢谢。有意见可以给我发Email
css默认样式:body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin:0;padding:0} table{border-collapse:collapse; border-spacing:0} fieldset,img{border:0} address,caption,cite,code,dfn,em,strong,th,var{font-style