您好,欢迎访问一九零五行业门户网

div+css的常见错误,兼容办法等_html/css_WEB-ITnose

常见错误
1. 检查html元素是否有拼写错误、是否忘记结束标记
即使是老手也经常会弄错div的嵌套关系。可以用dreamweaver的验证功能检查一下有无错误。
2. 检查css是否正确
检查一下有无拼写错误、是否忘记结尾的 } 等。可以利用cleancss来检查 css的拼写错误。cleancss本是为css减肥的工具,但也能检查出拼写错误。
3. 确定错误发生的位置
如果错误影响了整体布局,则可以逐个删除div块,直到删除某个div块后显示恢复正常,即可确定错误发生的位置。
4. 利用border属性确定出错元素的布局特性
使用float属性布局一不小心就会出错。这时为元素添加border属性确定元素边界,错误原因即水落石出。
5. float元素的父元素不能指定clear属性
macie下如果对float的元素的父元素使用clear属性,周围的float元素布局就会混乱。这是macie的著名的bug,倘若不知道就会走弯路。
6. float元素务必指定width属性
很多浏览器在显示未指定width的float元素时会有bug。所以不管float元素的内容如何,一定要为其指定width属性。
另外指定元素时尽量使用em而不是px做单位。
7. float元素不能指定margin和padding等属性
ie在显示指定了margin和padding的float元素时有bug。因此不要对float元素指定margin和padding属性(可以在float元素内部嵌套一个div来设置margin和padding)。也可以使用hack方法为ie指定特别的值。
8. float元素的宽度之和要小于100%
如果float元素的宽度之和正好是100%,某些古老的浏览器将不能正常显示。因此请保证宽度之和小于99%。
9. 是否重设了默认的样式?
某些属性如margin、padding等,不同浏览器会有不同的解释。因此最好在开发前首先将全体的margin、padding设置为0、列表样式设置为none等。
10. 是否忘记了写dtd?
如果无论怎样调整不同浏览器显示结果还是不一样,那么可以检查一下页面开头是不是忘了写下面这行dtd:
/p> 常用工具
1.notepad.exe记事本,(程序小,随时手工编辑,垃圾代码少,不能可视化预览)
2.dreamweaver(老牌网页编辑工具,功能全,程序比较大)
3..editplus(应该是升级版的记事本工具,代码编辑有颜色提示)
4.notepad++(一款非常有特色的编辑器,开源软件,支持多种开发语言)
5.ultraedit(一套功能强大的文本编辑器)
6.golive(将来替代dreamweaver的产品)
7.topstyle(功能相当多,附有css码检查功能,减少写错的机会。尤其是它的help文件中详细的css指令介绍,很适于用作参考文件与初次接触css的人做为学习使用)
兼容办法 区别ie6与ff: background:orange;*background:blue;
区别ie6与ie7: background:green !important;background:blue;
区别ie7与ff: background:orange; *background:green;
区别ff,ie7,ie6: background:orange;*background:green !important;*background:blue;
ie7,ie8兼容:
head
1. css中几种浏览器对不同关键字的支持,可进行浏览器兼容性重复定义 !important 可被firefox和ie7识别 * 可被ie6、ie7识别 _ 可被ie6识别 *+ 可被ie7识别
2. ie专用的条件注释
3. 几个浏览器对实际像素的解释 ie/opera:对象的实际宽度 = (margin-left) + width + (margin-right) firefox/mozilla:对象的实际宽度= (margin-left) + (border-left-width) + (padding- left) + width + (padding-right) + (border-right-width) + (margin-right)
4. 鼠标手势问题:firefox的cursor属性不支持hand,但是支持pointer,ie两个都支持;所以为了兼容都用pointer
5. firefox中设置html标签的style属性时,所有位置、宽高和尺寸值必须后跟px,ie也支持此写法,因此统一加px单位。如 obj.style.height = imgobj.style.height + ‘px';
6. firefox无法解析简写的padding属性设置,如padding 5px 4px 3px 1px;必须改为 padding-top:5px; padding-right:4px; padding-bottom:3px; padding-left:1px0;
7. 消除ul、ol等列表的缩进时,样式应写成:list-style:none;margin:0px;padding:0px;其中margin属性对ie有效,padding属性对firefox有效
8. css控制透明:ie:filter:progid:dximagetransform.microsoft.alpha(style=0,opacity=60); firefox:opacity:0.6;
9. css控制圆角:ie:不支持圆角; firefox: -moz-border-radius:4px;或 -moz-border-radius-topleft:4px; -moz-border-radius-topright:4px; -moz-border-radius-bottomleft:4px; -moz-border-radius- bottomright:4px;
10. css双线凹凸边框:ie:border:2px outset; firefox: -moz-border-top-colors: #d4d0c8 white; -moz-border-left-colors: #d4d0c8 white; -moz-border-right-colors:#404040 #808080; -moz-border-bottom-colors:#404040 #808080;
11. ie支持css方法cursor:url()自定义光标样式文件和滚动条颜色风格;firefox对以上两者均不支持
12. ie有select控件永远处于最上层的bug,且所有css对select控件都不起作用
13. ie支持form中的label标签,包括图片和文字内容;firefox不支持包含图片的label,点击图片不能让标记 label for 的radio或checkbox产生效果
14. firefox中的textarea不支持onscroll事件
15. firefox不支持display的inline和block
16. firefox对div设置margin-left, margin-right为auto时已经居中, ie中不行
17. firefox对body设置text-align时, div需要设置margin: auto(主要是margin-left margin-right) 方可居中
18. 对超链接的css样式设置最好遵从这样的顺序:l-v-h-a。即 这样可以避免一些访问过后的超链接就不具备hover和active样式了
19. ie中设置长段落自动换行在css中设置word-wrap:break-word;firefox中使用js插入 的方法来实现,具体代码如下:
20. 在子容器加了浮动属性后,该容器将不能自动撑开 解决方法:在标签结束后下一个标签中加上一个清除浮动的css clear:both;
21. 浮动后ie6解释外边距为实际边距的双倍 解决办法:加上display:inline
22. ie6下图片下方会有空隙 解决办法:为img加上display:block或设置vertical-align 属性为vertical-align:top | bottom |middle |text-bottom
23. ie6下两个层中间有空隙 解决办法:设置右侧div也同样浮动float:left或者相对ie6定义 margin-right:-3px;
24. li中内容超过长度后以省略号的显示方法 (只适用与ie)
25. 将元素的高度和行高设为相同值,即可垂直居中文本
26. 对齐文本与文本输入框,须在css中增加vertical-align:middle;属性设置
27. 支持web标准的浏览器设置了固定高度值就不会像ie6那样被撑开,但是又想设置固定高度又想能够被撑开呢?解决办法是去掉height属性而设置min-height,为了兼容不支持min-height的ie6可以这样定义: { height:auto!important; height:200px; min-height:200px; }
28. web标准中ie无法设置滚动条颜色 解决办法:在css中对body的设置改为对html的
29. ie6由于默认行高问题无法定义1px左右高度的容器, 解决办法:在css中对容器设置如:overflow:hidden | zoom:0.08 | line-height:1px
30. 给flash设置透明属性可使层显示在flash之上
其它类似信息

推荐信息