`

css各浏览器兼容性

    博客分类:
  • CSS
阅读更多
1、居中问题

div里的内容,ie默认为居中,而ff默认为左对齐。
使ff内容居中的方法是增加代码margin:auto;

eg: body{margin:0 auto;}



1、高度问题

设有两横行div排列,上面的div设置高度(height),如果div里的实际内容大于所设高度,在ff中会出现两个div重叠的现象;但在ie中,下面的div会自动给上面的div让出空间。所以为避免出现层的重叠,高度一定要控制恰当,或者干脆不写高度,让他自动调节。
或者设置:overflow:hidden

(如果要自动调节,ie7和ff会认最小高度min-height,但是ie6不认,所以为ie6加上_height:300;)[有点同6]



3、clear:both;  [万能]
拿footer为例,有时候如果上面使用了float控制的n列的布局,那么在用ff浏览时footer很有可能会到处乱动——因为他还在受到浮动(float)的控制。如果想让它正常显示,在footer的div中写入clear:both;就可以达到效果了!

(或者可以自定义一个block,调整两个div的间距 eg: .block{height:5px;clear:both;font-size:1px;margin:0 auto;} )



4、浮动ie产生的双倍距离
#box{
float:left;
width:100px;
margin:0 0 0 100px; //这种情况之下IE会产生200px的距离
display:inline; //使浮动忽略
}



5、display:block,inline两个元素 display(显示)
display:block; //可以为内嵌元素模拟为块元素     常用竖向导航

display:inline; //实现同一行排列的的效果     常用于横向导航制作中
diplay:table; //for ff,模拟table的效果

Display:block元素的特点是:总是在新行上开始
高度,行高以及顶和底边距都可控制;  //用line-height控制
宽度缺省是它的容器的100%,除非设定一个宽度
<div>, <p>, <h1>, <form>, <ul> 和 <li>是块元素的例子。

display:inline就是将元素显示为行内元素.
inline元素的特点是:
和其他元素都在一行上;
高,行高及顶和底边距不可改变;
宽度就是它的文字或图片的宽度,不可改变。
<span>, <a>, <label>, <input>, <img>, <strong> 和<em>是inline元素的例子。



6、IE与FF宽度和高度的问题
min -width是个非常方便的CSS命令,它可以指定元素最小也不能小于某个宽度,这样就能保证排版一直正确。整体最窄770px,最宽1024px,也就是说窗口小于770xp就出底部滚动条,如果大于1024px自动屏幕居中。IE不认得min-这个定义,但实际上它把正常的width和height当作有min的情况来使。这样,如果只用宽度和高度,正常的浏览器里这两个值就不会变,如果只用min-width和min-height的话,IE下面根本等于没有设置宽度和高度。
CSS这样设计:
#container{
min-width: 600px;
width:expression_r(document.body.clientWidth < 600? "600px": "auto" );
}

第一个min-width是正常的;但第2行的width使用了Javascrīpt,这只有IE才认得,这也会让你的HTML文档不太正规。它实际上通过Javascrīpt的判断来实现最小宽度。

同样的办法也可以为IE实现最大宽度:
#container
{
min-width: 600px;
max-width: 1200px;
width:expression_r(document.body.clientWidth < 600? "600px" : document.body.clientWidth > 1200? ”1200px“ : ”auto";}



7、FF: 支持 !important, IE 则忽略
可用 !important (例:height:30px!important; height:26px;)为 FF 特别设置样式
div 的垂直居中问题: vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行
cursor: pointer 可以同时在 IE FF 中显示游标手指状, hand 仅 IE 可以
FF: 链接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行(背景图片需要设置 float: left )。参照 menubar, 给 a 和 menubar 设置高度是为了避免底边显示错位, 若不设 height, 可以在 menubar 中插入一个空格
在FF和IE中的BOX模型解释不一致导致相差2px解决方法:
div{margin:30px!important;margin:28px;}

注意这两个margin的顺序一定不能写反,!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样:


div{maring:30px;margin:28px}

重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;


在Firefox/Mozilla 浏览器中,对象的实际宽度= (margin-left) + (border-left-width) + (padding- left) + width + (padding-right) + (border-right-width) + (margin-right);而在IE/Opera浏览器中,对象的实际宽度 = (margin-left) + width + (margin-right)。





构架中的兼容性

1、解决超链接访问过后hover样式不显示的问题


改变CSS属性的排列顺序: 先后顺序标准应为:a:link—a:visited—a:hover—a:active

2、Li中内容超过长度后以省略号显示的方法

<meta content="text/html; charset=gb2312" http-equiv="Content-Type" />

<style type="text/css">
<!--
li {
     width:200px;
     white-space:nowrap;    //定义列表不进行换行
     text-overflow:ellipsis;    //裁剪过长的文字同时添加“...” 但ff不认

     -o-text-overflow:ellipsis;
     overflow: hidden;}
-->

</style>
<ul>
     <li><a href="#">web标准常见问题大全web标准常见问题大全</a></li>
     <li><a href="#">web标准常见问题大全web标准常见问题大全</a></li>
</ul>




3、解决IE不能正确显示透明PNG——header内加入代码



程序代码
<script language="javascript">
function correctPNG()
{
for(var i=0; i<document.images.length; i++)
{
   var img = document.images[i]
   var imgName = img.src.toUpperCase()
   if (imgName.substring(imgName.length-3, imgName.length) == "PNG")
   {
    var imgID = (img.id) ? "id='" + img.id + "' " : ""
    var imgClass = (img.className) ? "class='" + img.className + "' " : ""
    var imgTitle = (img.title) ? "title='" + img.title + "' " : "title='" + img.alt + "' "
    var imgStyle = "display:inline-block;" + img.style.cssText
    if (img.align == "left") imgStyle = "float:left;" + imgStyle
    if (img.align == "right") imgStyle = "float:right;" + imgStyle
    if (img.parentElement.href) imgStyle = "cursor:hand;" + imgStyle
    var strNewHTML = "<span " + imgID + imgClass + imgTitle
    + " style=\"" + "width:" + img.width + "px; height:" + img.height + "px;" + imgStyle + ";"
   + "filter:progid:DXImageTransform.Microsoft.AlphaImageLoader"
    + "(src=\'" + img.src + "\', sizingMethod='scale');\"></span>"
    img.outerHTML = strNewHTML
    i = i-1
   }
}
}
window.attachEvent("onload", correctPNG);
</script>

4、BOX模型在firefox和IE中的解释相差2px的解决方法
div{margin:30px!important;margin:28px;}

注意这两个margin的顺序一定不能写反。根据上面提到的IE并不支持!important,所以在IE下其实解释成这样:
div{maring:30px;margin:28px}

重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;


5、去掉链接的虚线样式
a{blr:e-xpression(this.onFocus=this.close()); text-decoration:none; color:#333;}  //针对ie
a:focus{-moz-outline-style:none;}   //针对ff
a,area{blr:expression_r(this.onFocus=this.blur());}   //针对ie 去点图片链接的虚线

6、ie6对line-height的失效
在ie6中,当文字和img、input、textarea、select、object等对象在同一个容器中的时候,line-height属性失效。只有全文字时,line-height属性才有效。
可以在其中一个非文字的对象的样式中增加: margin: (容器的line-height - 对象本身的高度)/2px 0;  vertical-align:middle; 解决问题。
7、有时候两个div直接会产生缝隙
可以在两个大的div中设置font-size:0px;然后再在里面一层的div中设置文字的正确大小

8.禁止选取网页内容
在IE中一般用js:obj.onselectstart=function(){return false;}
而ff用CSS:-moz-user-select:none;

9.CSS透明问题
IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。
FF:opacity:0.6;
(最好两个都写,并将opacity属性放在下面。)

10. 关于手形光标
cursor: pointer; //而hand 只适用于 IE

11.用css控制图片大小

   max-width:500px;      //最大宽度为500

   width:expression_r(this.width>500?"500px":this.width+"px");  //图片超过500,以500的宽度显示,

                                                                小于500则按原图大小显示



各个游览器的HACK
IE6 专用
_height: 100px;

IE6 IE7 共用
*height: 100px;

IE7 专用
*+height: 100px;

所以IE6、7、8 共用
height: 100px\9; (可以直接把ie和ff区别开)

IE7  FF 共用
height: 100px !important;



最新的ie8 可以直接把它打回ie7来显示

<meta http-equiv="X-UA-Compatible" content="IE=7"/>




css文字简写规律
font-weight:bold;   //宽度

font-style:italic;  //样式斜体

font-varient:small-caps;  //这个属性对中文字没有影响,是规定英文字母的大小

font-size:1em;      //大小

line-height:1.5em;   //行高

font-family:verdana,sans-serif; //字体



但也可以把它们全部写到一行上去:

font: bold italic small-caps 1em/1.5em verdana,sans-serif;

这种简写方法只有在同时指定font-size和font-family属性时才起作用。而且,如果你没有设定font-weight, font-style, 以及 font-varient ,他们会使用缺省值
分享到:
评论

相关推荐

    css 浏览器兼容性速查

    "CSS浏览器兼容性速查"是开发者在工作中不可或缺的一个参考资料,它帮助我们了解各种CSS属性在不同浏览器上的表现,以便于优化代码,确保网站在主流浏览器上都能正常显示。 首先,我们要理解浏览器兼容性问题的来源...

    Css与各浏览器兼容性

    解决浏览器兼容性问题的最佳实践包括遵循W3C标准编写CSS,使用reset.css重置浏览器默认样式,利用CSS预处理器(如Sass或Less)简化代码,以及利用条件注释或特性检测库(如Modernizr)为不同浏览器提供特定样式。...

    CSS-浏览器兼容实战.pdf

    本书分为基础篇和实战篇,旨在帮助开发者理解和应对CSS的跨浏览器兼容性挑战。 基础篇首先介绍了DIV+CSS的优势,这种布局方式使得表现和内容分离,提高了搜索引擎的索引效率,减少了代码量,加快了页面加载速度,...

    css hack浏览器兼容性

    css hack ie6 ie7 ie8 firefox等浏览器兼容性

    CSS各浏览器兼容解决总结

    在网页设计中,CSS(层叠样式表)的浏览器兼容性问题是一大挑战,尤其是在不同浏览器之间,如Internet Explorer(IE)和Firefox等。本文主要针对CSS在浏览器兼容性方面的一些常见问题及其解决策略进行总结。 1. **...

    div+css中常见的浏览器兼容性处理

    【CSS浏览器兼容性处理】 在Web开发中,CSS(层叠样式表)是用于控制网页元素样式的关键技术。然而,不同的浏览器对CSS的理解和解析方式存在差异,这可能导致在某些浏览器下网页显示不正常。特别是在使用div+css...

    别具光芒——CSS属性、浏览器兼容与网页布局

    "别具光芒——CSS属性、浏览器兼容与网页布局"这个主题涵盖了三个核心概念:CSS属性、浏览器兼容性和网页布局。 首先,我们来详细探讨CSS属性。CSS提供了无数的属性,如颜色、字体、大小、位置等,这些属性共同决定...

    css 多浏览器兼容解决方案 下载

    CSS 多浏览器兼容性是Web开发中的重要环节,因为不同的浏览器对CSS的解析方式可能存在差异,这可能导致在不同浏览器中页面展示效果不一致。以下是一些关键知识点和解决方案: 1. **DOCTYPE影响CSS处理**: DOCTYPE...

    CSS常见浏览器兼容问题

    然而,由于各个浏览器之间的实现差异,CSS的兼容性问题常常成为开发者们面临的一大挑战。尤其是IE(Internet Explorer)和Firefox,它们在解析CSS规则时有着不同的理解和执行方式。本篇文章将深入探讨CSS在不同...

    css浏览器兼容.docx

    CSS浏览器兼容性问题解决方案 CSS浏览器兼容性问题是Web开发中常见的问题。不同的浏览器对CSS的解析方式不同,这就导致了浏览器之间的兼容性问题。了解浏览器的兼容性问题是非常重要的,为此,我们总结了一些常见的...

    最全的CSS浏览器兼容问题

    以下是一些常见的CSS浏览器兼容性问题及其解决方案: 1. **垂直居中问题**: 在CSS中,要实现一个div的垂直居中,可以使用`vertical-align: middle;`和`line-height`属性。但这种方法要求内容不换行。例如: ```...

    CSS在不同浏览器中兼容问题

    * 针对多种浏览器分别配置合适的 CSS 文件,再通过判断浏览器选择不同 CSS 实现兼容性 * 使用 &lt;!--[endif]--&gt; 等方法来区分不同浏览器 CSS 在不同浏览器中的兼容问题是一个复杂的问题,需要认真对待和解决。通过...

    机器猫 CSS3测试浏览器对CSS3的兼容性.zip

    机器猫 CSS3测试浏览器对CSS3的兼容性

    跨浏览器兼容CSS篇

    ### 跨浏览器兼容CSS篇:实现一致性的策略与技巧 #### 一、引言 在Web设计领域,确保网站在不同浏览器中呈现一致的效果是一项挑战性任务。由于各种浏览器对CSS的支持程度不尽相同,开发者经常面临布局差异的问题。...

    CSS技巧汇总---div+CSS浏览器兼容问题整理

    CSS技巧汇总---div+CSS浏览器兼容问题整理(IE6.0、IE7.0 ,ie8 , FireFox...).pdf

    CSS浏览器兼容性学习

    CSS浏览器兼容性学习旨在确保网站在不同浏览器下都能正常显示和功能完整。以下是关于这个主题的一些关键知识点: 一、CSS Hack 1. `!important` Hack:在IE7之后的浏览器支持`!important`规则,可以用来区分IE6和...

    css浏览器兼容写法

    总之,处理CSS浏览器兼容性问题需要深入理解各个浏览器的解析机制和特性,并熟练运用各种兼容性写法。通过适当的选择器、属性hack以及媒体查询,可以有效地确保样式在多种浏览器中表现一致,提升用户体验。

    CSS多浏览器兼容性[定义].pdf

    在网页设计中,CSS(层叠样式表)的浏览器兼容性是一个常见的挑战,尤其是在处理不同浏览器,如Internet Explorer(IE)和Firefox时。以下是一些关于CSS多浏览器兼容性的关键知识点: 1. **DOCTYPE声明**:为了确保...

Global site tag (gtag.js) - Google Analytics