1. cursor:hand VS cursor:pointercss
2. innerText在IE中能正常工做,但在FireFox中却不行html
3. CSS透明web
4. css中的width和paddingchrome
5. FF和IE BOX模型解释不一致致使相差2pxexpress
6. IE5 和IE6的BOX解释不一致浏览器
7. ul和ol列表缩进问题app
8. 元素水平居中问题ide
9. Div的垂直居中问题ui
10. margin加倍的问题spa
11. IE与宽度和高度的问题
12. 页面的最小宽度
13. DIV浮动IE文本产生3象素的bug
14. IE捉迷藏的问题
15. float的div闭合;清除浮动;自适应高度
16. 高度不适应
17. IE6下图片下有空隙产生
18. 对齐文本与文本输入框
19. LI中内容超过长度后以省略号显示
20. 为何web标准中IE没法设置滚动条颜色了
21. 为何没法定义1px左右高度的容器
22. 连接(a标签)的边框与背景
23. 超连接访问事后hover样式就不出现的问题
24. FORM标签
25. 属性选择器(这个不能算是兼容,是隐藏css的一个bug)
26. 为何FF下文本没法撑开容器的高度
firefox不支持hand,但ie支持pointer
解决方法: 统一使用pointer
需用textContent。
解决方法:
if(navigator.appName.indexOf("Explorer") > -1){
document.getElementById('element').innerText = "my text";
} else{
document.getElementById('element').textContent = "my text";
}
IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。
FF:opacity:0.6。
在IE7和FF中width宽度不包括padding,在Ie6中包括padding.
box.style{width:100;border 1px;}
ie理解为box.width = 100
ff理解为box.width = 100 + 1*2 = 102 //加上边框2px
解决方法:div{margin:30px!important;margin:28px;}
注意这两个margin的顺序必定不能写反, IE不能识别!important这个属性,但别的浏览器能够识别。因此在IE下其实解释成这样:div{maring:30px;margin:28px}
重复定义的话按照最后一个来执行,因此不能够只写margin:XXpx!important;
IE5下div{width:300px;margin:0 10px 0 10px;}
div 的宽度会被解释为300px-10px(右填充)-10px(左填充),最终div的宽度为280px,而在IE6和其余浏览器上宽度则是以 300px+10px(右填充)+10px(左填充)=320px来计算的。这时咱们能够作以下修改 div{width:300px!important;width /**/:340px;margin:0 10px 0 10px}
消除ul、ol等列表的缩进时,样式应写成:list-style:none;margin:0px;padding:0px;
经验证,在IE中,设置margin:0px能够去除列表的上下左右缩进、空白以及列表编号或圆点,设置padding对样式没有影响;在 Firefox 中,设置margin:0px仅仅能够去除上下的空白,设置padding:0px后仅仅能够去掉左右缩进,还必须设置list- style:none才能去除列表编号或圆点。也就是说,在IE中仅仅设置margin:0px便可达到最终效果,而在Firefox中必须同时设置margin:0px、 padding:0px以及list-style:none三项才能达到最终效果。
FF: margin:0 auto;
IE: 父级{ text-align:center; }
vertical-align:middle; 将行距增长到和整个DIV同样高:line-height:200px; 而后插入文字,就垂直居中了。缺点是要控制内容不要换行。
设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。解决方案是在这个div里面加上display:inline;
例如:
<div id=”imfloat”>
相应的css为
#imfloat{
float:left;
margin:5px;/*IE下理解为10px*/
display:inline;/*IE下再理解为5px*/}
IE不认得min-这个定义,但实际上它把正常的width和height看成有min的状况来使。这样问题就大了,若是只用宽度和高度,正常的浏览器里这两个值就不会变,若是只用min-width和min-height的话,IE下面根本等于没有设置宽度和高度。
好比要设置背景图片,这个宽度是比较重要的。要解决这个问题,能够这样:
#box{ width: 80px; height: 35px;}html>body #box{ width: auto; height: auto; min-width: 80px; min-height: 35px;}
如上一个问题,IE不识别min,要实现最小宽度,可用下面的方法:
#container{ min-width: 600px; width:expression(document.body.clientWidth< 600? "600px": "auto" );}
第一个min-width是正常的;但第2行的width使用了Javascript,这只有IE才认得,这也会让你的HTML文档不太正规。它实际上经过Javascript的判断来实现最小宽度。
左边对象浮动,右边采用外补丁的左边距来定位,右边对象内的文本会离左边有3px的间距.
#box{ float:left; width:800px;}
#left{ float:left; width:50%;}
#right{ width:50%;}
*html #left{ margin-right:-3px; //这句是关键}
<div id="box">
<div id="left"></div>
<div id="right"></div>
</div>
当div应用复杂的时候每一个栏中又有一些连接,DIV等这个时候容易发生捉迷藏的问题。
有些内容显示不出来,当鼠标选择这个区域是发现内容确实在页面。
解决办法:对#layout使用line-height属性或者给#layout使用固定高和宽。页面结构尽可能简单。
① 例如:<div id=”floatA”><div id=”floatB”><div id=”NOTfloatC”>
这里的NOTfloatC并不但愿继续平移,而是但愿往下排。(其中floatA、floatB的属性已经设置为float:left;)
这段代码在IE中毫无问题,问题出在FF。缘由是NOTfloatC并不是float标签,必须将float标签闭合。在<div class=”floatB”><div class=”NOTfloatC”>之间加上<div class=”clear”>这个div必定要注意位置,并且必须与两个具备float属性的div同级,之间不能存在嵌套关系,不然会产生异常。而且将clear这种样式定义为为以下便可:.clear{clear:both;}
②做为外部 wrapper 的 div 不要定死高度,为了让高度能自适应,要在wrapper里面加上overflow:hidden; 当包含float的box的时候,高度自适应在IE下无效,这时候应该触发IE的layout私有属性(万恶的IE啊!)用zoom:1;能够作到,这样就达到了兼容。
例如某一个wrapper以下定义:
.colwrapper{overflow:hidden; zoom:1; margin:5px auto;}
③对于排版,咱们用得最多的css描述可能就是float:left.有的时候咱们须要在n栏的float div后面作一个统一的背景,譬如:
<div id=”page”>
<div id=”left”></div>
<div id=”center”></div>
<div id=”right”></div>
</div>
好比咱们要将page的背景设置成蓝色,以达到全部三栏的背景颜色是蓝色的目的,可是咱们会发现随着left center right的向下拉长,而page竟然保存高度不变,问题来了,缘由在于page不是float属性,而咱们的page因为要居中,不能设置成float,因此咱们应该这样解决:
<div id=”page”>
<div id=”bg” style=”float:left;width:100%”>
<div id=”left”></div>
<div id=”center”></div>
<div id=”right”></div>
</div>
</div>
再嵌入一个float left而宽度是100%的DIV解决之。
④万能float 闭合(很是重要!)
关于 clear float 的原理可参见 [How To Clear Floats Without Structural Markup],将如下代码加入Global CSS 中,给须要闭合的div加上class="clearfix" 便可,屡试不爽。
/* Clear Fix */
.clearfix:after { content:"."; display:block; height:0; clear:both; visibility:hidden; }
.clearfix { display:inline-block; }
/* Hide from IE Mac */
.clearfix {display:block;}
/* End hide from IE Mac */
/* end of clearfix */
或者这样设置:.hackbox{ display:table; //将对象做为块元素级的表格显示}
高度不适应是当内层对象的高度发生变化时外层高度不能自动进行调节,特别是当内层对象使用margin 或padding时。
例:
#box {background-color:#eee; }
#box p {margin-top: 20px;margin-bottom: 20px; text-align:center; }
<div id="box">
<p>p对象中的内容</p>
</div>
解决技巧:在P对象上下各加2个空的div对象CSS代码{height:0px;overflow:hidden;}或者为DIV加上border属性。
解决这个BUG的技巧有不少,能够是改变html的排版,或者设置img为display:block或者设置vertical-align属性为vertical-align:top/bottom/middle/text-bottom 均可以解决.
加上vertical-align:middle;
<style type="text/css">
<!--
input {
width:200px;
height:30px;
border:1px solid red;
vertical-align:middle;
}
-->
</style>
经验证,在IE下任一版本都不适用,而ff、opera、safari、chrome均OK!
此技巧适用与IE、Opera、safari、chrom浏览器,FF暂不支持。
<style type="text/css">
<!--
li {
width:200px;
white-space:nowrap;
text-overflow:ellipsis;
-o-text-overflow:ellipsis;
overflow: hidden;
}
-->
</style>
解决办法是将body换成html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<style type="text/css">
<!--
html {
scrollbar-face-color:#f6f6f6;
scrollbar-highlight-color:#fff;
scrollbar-shadow-color:#eeeeee;
scrollbar-3dlight-color:#eeeeee;
scrollbar-arrow-color:#000;
scrollbar-track-color:#fff;
scrollbar-darkshadow-color:#fff;
}
-->
</style>
IE6下这个问题是由于默认的行高形成的,解决的技巧也有不少:
例如:overflow:hidden zoom:0.08 line-height:1px
16.怎么样才能让层显示在FLASH之上呢
解决的办法是给FLASH设置透明
<param name="wmode" value="transparent" />
a连接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行。参照menubar, 给 a 和menubar设置高度是为了不底边显示错位, 若不设 height, 能够在menubar中插入一个空格。
被点击访问过的超连接样式不在具备hover和active了,不少人应该都遇到过这个问题,解决技巧是改变CSS属性的排列顺序: L-V-H-A
Code:
<style type="text/css">
<!--
a:link {}
a:visited {}
a:hover {}
a:active {}
-->
</style>
这个标签在IE中,将会自动margin一些边距,而在FF中margin则是0,所以,若是想显示一致,因此最好在css中指定margin和 padding,针对上面两个问题,个人css中通常首先都使用这样的样式ul,form{margin:0;padding:0;}。
p[id]{}div[id]{}
这个对于IE6.0和IE6.0如下的版本都隐藏,FF和OPera做用.属性选择器和子选择器仍是有区别的,子选择器的范围从形式来讲缩小了,属性选择器的范围比较大,如p[id]中,全部p标签中有id的都是一样式的.
标准浏览器中固定高度值的容器是不会象IE6里那样被撑开的,那我又想固定高度,又想能被撑开须要怎样设置呢?办法就是去掉height设置min-height:200px; 这里为了照顾不认识min-height的IE6 能够这样定义:
{ height:auto!important; height:200px; min-height:200px; }