div+css 兼容小摘
来源: 阅读:646 次 日期:2014-12-22 14:57:57
温馨提示: 小编为您整理了“div+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兼容:

<meta http-equiv=x-ua-compatible content=ie=emulateie7 />

head

1. css中几种浏览器对不同关键字的支持,可进行浏览器兼容性重复定义

!important 可被firefox和ie7识别

* 可被ie6、ie7识别

_ 可被ie6识别

*+ 可被ie7识别

2. ie专用的条件注释

<!--其他浏览器 -->

<link rel=stylesheet type=text/css href=css.css />

<!--[if ie 7]>

<!-- 适合于ie7 -->

<link rel=stylesheet type=text/css href=ie7.css />

<![endif]-->

<!--[if lte ie 6]>

<!-- 适合于ie6及一下 -->

<link rel=stylesheet type=text/css href=ie.css />

<![endif]-->

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。即

<style type=text/css>

<!--

a:link {}

a:visited {}

a:hover {}

a:active {}

-->

</style>

这样可以避免一些访问过后的超链接就不具备hover和active样式了

19. ie中设置长段落自动换行在css中设置word-wrap:break-word;firefox中使用js插入 的方法来实现,具体代码如下:

<script type=text/javascript>

/* <![cdata[ */

function tobreakword(el, intlen){

var obj=document.getelementbyid(el);

var strcontent=obj.innerhtml;

var strtemp=;

while(strcontent.length>intlen){

strtemp+=strcontent.substr(0,intlen)+ ;

strcontent=strcontent.substr(intlen,strcontent.length);

}

strtemp+= +strcontent;

obj.innerhtml=strtemp;

}

if(document.getelementbyid && !document.all) tobreakword(div_id, 37);

/* ]]> */

</script>

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中内容超过长度后以省略号的显示方法

<style type=text/css>

<!--

li {

width:200px;

white-space:nowrap;

text-overflow:ellipsis;

-o-text-overflow:ellipsis;

overflow: hidden;

}

-->

</style>

25. 将元素的高度和行高设为相同值,即可垂直居中文本

<style type=text/css>

<!--

div {

height:30px;

line-height:30px;

}

-->

</style>

26. 对齐文本与文本输入框,须在css中增加vertical-align:middle;属性设置

<style type=text/css>

<!--

… …

vertical-align:middle;

}

-->

</style>

27. 支持web标准的浏览器设置了固定高度值就不会像ie6那样被撑开,但是又想设置固定高度又想能够被撑开呢?解决办法是去掉height属性而设置min-height,为了兼容不支持min-height的ie6可以这样定义:

{

height:auto!important;

height:200px;

min-height:200px;

}

28. web标准中ie无法设置滚动条颜色

解决办法:在css中对body的设置改为对html的

<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>

29. ie6由于默认行高问题无法定义1px左右高度的容器,

解决办法:在css中对容器设置如:overflow:hidden | zoom:0.08 | line-height:1px

30. 给flash设置透明属性可使层显示在flash之上

<param name=wmode value=transparent /> <!-- 解决ie上的问题 //>

<embed wmode=transparent …… > <!-- 解决firefox上的问题 //>

31. firefox设置padding属性后会相应的增加width和height属性值,ie不会

解决办法:用!important方法多定义一套height和width

32. firefox对div与div之间的空格是忽略的,但ie是处理的;因此尽量在两个相连的div之间不要有空格和回车,否则可能会造成不同浏览器之间格式不正确,比如著名的3px偏差;而且原因很难查明

33. 形如如下格式

<div id=parent>

<div id=content> </div>

</div>

当content内容多时,即使parent设置了高度100%或auto,在不同浏览器下还是不能完好的自动伸展;解决办法在层的最下方产生一个高度为1的空格,代码如下

<div id=parent>

<div id=content> </div>

<div style=font: 0px/0px sans-serif;clear: both;display: block> </div>

</div>

34. ie和firefox对字体small的尺寸解释不同,firefox为13px,ie中为16px

35. ie和firefox对空格的尺寸解释不同,firefox为4px,ie中为8px

首先,关于css hack的方法网上有很多介绍,种类繁多,初学者常常感到很困惑。这类的css hack的方法,有的是针对某一个非常特殊的情况的方法,有的则是相对于比较通用的一些方法。

对于后者我们在平常的学习工作中,可以多留心收集一些,前者则不需要太关注,只是遇到的时候到网上搜索一下,寻找解决方法即可。

这里举一个比较通用的hack方法,比如对于css中的某一个属性,我们希望针对不同的浏览器,设置不同的值。例如,某一个div,我们希望在firefox中宽度为50像素,在ie中宽度为60像素。那么怎么实现呢?请看如下代码:

#demo div{

width:50px; /* firefox 有效 */

+width:60px; /* ie 有效 */

}

在上面的代码中, 第2行的width:50px这是普通的样式,下一行中,在width属性前面加一个加号,这条样式在firefox中被认为无效,但是在ie中这个加号 会被忽略掉,因此仍然被理解为width属性,从而覆盖上一条的设置,这样就可以区分firefox浏览器和ie浏览器了。

那么如果希望进一步区分ie 6和ie 7呢?请看如下代码:

#demo div{

width:50px; /* firefox 有效 */

+width:60px; /* ie 7 有效 */

_width:70px; /* ie 6 有效 */

}

上面代码就可以实现对三种浏览器的区分了。在ie7中,属性前加一个加号,这个加号会被忽略,而如果在属性前加一个下划线这整条样式会被忽略,从而实现了对这三种主流浏览器的区分。

到这里,我们自然会想到,什么情况下会用的这种方法来区分浏览器呢?我们要制作的页面,通常会有两种情况,一种是彻底从头开始做,另一种是基于一个已经存在的网页进行修改或者修补。

对于第一种情况来说,我们对网页的每一个细节都十分清楚,因此并不经常遇到非常firefox和ie的兼容性问题,即使遇到了,一般也可以找到其他 方法解决。而对于第二种情况来说,则复杂的多了,因为一个网页可能非常复杂,层叠关系也很复杂,对于后接手的人,很难搞清楚某一个的属性上面有多少层设置 会对他产生影响,因此往往只能采用“贴膏药”的方式进行修补。

比如说,如下的一个页面的最终效果,在制作圆角框的时候,在ie中,圆角对整齐之后,在firefox中却出现如图所示的错位,而如果按照firefox调整好,在ie中又会出现错位。

而页面的内容层层嵌套,在并不知道细节的情况下,很难找到问题的根源。因此这里使用修补的方法就很方便(尽管不是最优雅完善的方法),例如对于控制圆角图像位置的属性使用上面的方法,分别控制即可。

总上所述,对任何属性都可以使用加号或者下划线方法,来实现针对不同浏览器的各自设置。当然,最后还是要指出,任何hack方法都要慎重使用,最好还是能够按照标准、优雅的css来进行设计,这样的代码可读性、维护性都要好很多,也是我们追求的目标。

为什么div+css在ie6没问题,在firfox有问题,严重走样,什么原因,谢谢

ie和ff的比较大的区别是1。在1024的分辨率下 ie最多显示1002px ff显示1005px2。ie容错性超级强 也就是说 你代码写错了 少写了 也有可能显示正确 ff就不行~~~`一般新手常常出现的问题:没有清除浮动~~~~.clear{ clear:both; height:1px; top:-1px; overflow:hidden}在每一个浮动后面都加上一个<div class=clear><div>

更多信息请查看IT技术专栏

更多信息请查看网页制作
手机网站地址:div+css 兼容小摘
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map