IE:
IE 的双边距 bug:
块级元素 float 后设置横向的 margin,IE6 显示的 margin 比较大.
解决办法: display:inline
双边距 bug: 在 IE6 下, 如果对元素设置浮动, 同时又设置了 margin-left 或 margin-right,margin 值会加倍
#box{ float:left; width:10px; margin:0 0 0 10px;}
这种情况之下 IE 会产生 20px 的距离
解决方案: 在 float 的标签样式控制中加入 _display:inline; 将其转化为行内属性.( _ 这个符号只有 ie6 会识别)
IE6 不支持 PNG 透明背景, 对 PNG 格式的图片不友好
解决办法: IE6 下使用 gif 图片
或采用下述 PNG 兼容 IE6 解决方法
IE5-8 不支持 opacity
解决办法:
- .opacity {
- opacity: 0.4
- filter: alpha(opacity=60); /* for IE5-7 */
- -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)"; /* for IE
- 8*/
- }
IE6 默认的行高造成没有办法定义 1px 左右的宽度容器
解决方法:
- {
- overflow:hidden;
- zoom:0.08;
- line-height:1px;
- }
谷歌
默认会将小于 12px 的文本设置按照 12px 显示
解决方法: 统一通过 getAttribute() 获取自定义属性
浏览器
浏览器默认的 margin 和 padding 不同
解决方案: 加一个全局的 *{margin:0;padding:0;} 来统一.
超链接访问过后 hover 样式就不出现了, 被点击访问过的超链接样式不在具有 hover 和 active 了
解决方法: 改变 CSS 属性的排列顺序 L-V-H-A
- a:link {}
- a:visited {}
- a:hover {}
- a:active {}
上下 margin 重合问题:
IE 和 ff 都存在, 相邻的两个 div 的 margin-left 和 margin-right 不会重合, 但是 margin-top 和 margin-bottom 却会发生重合.
解决方法: 养成良好的代码编写习惯, 同时采用 margin-top 或者同时采用 margin-bottom.
IE 下, 可以使用获取常规属性的方法来获取自定义属性, 也可以使用 getAttribute() 获取自定义属性; Firefox 下, 只能使用 getAttribute() 获取自定义属性
解决方法: 统一通过 getAttribute() 获取自定义属性
IE 下, event 对象有 x,y 属性, 但是没有 pageX,pageY 属性; Firefox 下, event 对象有 pageX,pageY 属性, 但是没有 x,y 属性
解决方法:(条件注释) 缺点是在 IE 浏览器下可能会增加额外的 HTTP 请求数.
怪异模式问题
漏写 DTD 声明, Firefox 仍然会按照标准模式来解析网页, 但在 IE 中会触发怪异模式.
为避免怪异模式给我们带来不必要的麻烦, 最好养成书写 DTD 声明的好习惯.
来源: http://www.bubuko.com/infodetail-2806220.html