各种浏览器兼容篡位的css样式写法
谷歌浏览器的识别
@media screen and (-webkit-min-device-pixel-ratio:0) {
height:10px;
} IE6特制识别的
*HTML .SearchBox {
height:10px;
} Firefox浏览器的内核
@-moz-document url-prefix() {
.font1 {color:red}
} 二、针对样式名
如果只让ie6看见用
*html .head{color:#000;}
如果只让ie7看见用
*+html .head{color:#000;}
如果只让ff看见用
:root body .head{color:#000;}
如果只让ff、IE8看见用
html>body .head{color:#000;}
如果只是不让ie6看见用
html>body .head{color:#000;}
即对IE 6无效 如果只是不让ff、IE8看见用
*body .head{color:#000;}
即对ff、IE8无效 三、针对具体属性
如果只让ie6看见用
.head{_color:#000;}
如果只让ie7看见用+与_结合的方法
.head{+color:#f00;!;_color:#000;}
IE8正式版hack"\9″
例:”margin:0px auto\9;”
这里的”\9″可以区别所有IE8和FireFox.
"*"IE6、IE7可以识别.IE8、FireFox不能.
“_”IE6可以识别”_”,IE7、IE8、FireFox不能.
如:
.a {color:#f00;
+color:#00FF00;
_color:#0000FF;
}
从左到右分别对应FF,IE8 IE7 IE6
还有写css样式一定要记住顺序:
以下为引用的内容:
#1 { color: #333; }
* html #1 { color: #666; }
*+html #1 { color: #999; }
顺序很重要
四、针对各种浏览器css不兼容的写法
P{+color:#f00;} 支持IE7 IE6不支持FF IE8
P{_color:#f00;} 支持ie6不支持FF
P{color:#f00; !important;}
P{color:#f00;} 支持IE6 IE7 IE8b FF
P{color:#00f !important;color:#f00; } 支持IE7 IE8b FF不支持IE6
head:first-child+body p{color:#f00;} 支持IE7 IE8b FF不支持IE6
支持IE8b不支持IE6 IE7 FF
html*{color:#f00} 支持IE7 IE6不支持FF IE8
body>p{color:#f00} 支持IE7 IE8b FF不支持IE6
html[xmlns] p {color:#f00} 支持IE7 IE8b FF不支持IE6
@import "style.css"
@import url(style.css)
@import url('style.css')
@import url("style.css")
支持IE6 IE7 IE8b FF
P{} 支持IE6 IE7 FF不支持IE8b
五、CSS技巧
FF与IE
1. Div居中问题
div设置margin-left, margin-right 为auto 时已经居中,IE
不行,IE需要设定body居中,首先在父级元素定义text-algin:
center;这个的意思就是在父级元素内的内容居中。
2.链接(a标签)的边框与背景a 链接加边框和背景色,需设置display:
block,同时设置float:left保证不换行。
3.超链接访问过后hover样式就不出现的问题被点击访问过的超链接样式不在具有hover和active了,
很多人应该都遇到过这个问题,解决方法是改变CSS属性的排列顺序:L-V-H-A
Code:
4.游标手指cursor cursor: pointer 可以同时在IE FF 中显示游标手指状,hand仅IE可以
5.UL的padding与marginul标签在FF中默认是有padding值的,而在IE中只有margin默认有值,所以先定义ul{margin:0;padding:0;}就能解决大部分问题
6.
FORM标签这个标签在IE中,将会自动margin一些边距,而在FF中margin则是0,因此,如果想显示一致,所以最好在css中指定margin和padding,针对上面两个问题,我的css中一般首先都使用这样的样式ul,form{margin:0;padding:0;}给定义死了所以后面就不会为这个头疼了.
7. BOX模型解释不一致问题在FF和IE中的BOX模型解释不一致导致相差2px
解决方法:
div{margin:30px!important;margin:28px;}
margin顺序不能写反important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样:
div {maring:30px;margin:28px}重复定义的话按照最后一个来执行,所以不可以只写
margin:xx px!important;
#box{
width:600px;
//for ie6.0-w\idth:500px;
//for ff+ie6.0
}
#box{ width:600px!important //for ff
width:600px; //for ff+ie6.0 width
:500px; //for ie6.0-
}
8.属性选择器(这个不能算是兼容,是隐藏css的一个bug)p[id]{}div[id]{}这个对于IE6.0和IE6.0以下的版本都隐藏,FF和OPera作用.属性选择器和子选择器还是有区别的,子选择器的范围从形式来说缩小了,属性选择器的范围比较大,如p[id]中所有p标签中有id的都是同样式的.
9.最狠的手段-!important;如果实在没有办法解决一些细节问题,可以用这个方法.FF对于”!important”
会自动优先解析,然而IE则会忽略.
如下
.tabd1{
background:url(/res/images/up/tab1.gif) no-repeat 0px 0px
!important;
background:url(/res/images/up/tab1.gif) no-repeat 1px 0px; }
值得注意的是,一定要将xxxx !important这句放置在另一句之上,上面已经提过
10.IE,FF的默认值问题或许你一直在抱怨为什么要专门为IE和FF写不同的CSS,为什么IE这样让人头疼,然后一边写css,一边咒骂那个可恶的M$
IE.其实对于css的标准支持方面,IE并没有我们想象的那么可恶,关键在于IE和FF的默认值不一样而已,掌握了这个技巧,你会发现写出兼容IE和FF的css并不是那么困难,或许对于简单的css,你完全可以不用”!important”这个东西了。
我们都知道,浏览器在显示网页的时候,都会根据网页的css样式表来决定如何显示,但是我们在样式表中未必会将所有的元素都进行了具体的描述,当然也没有必要那么做,所以对于那些没有描述的属性,浏览器将采用内置默认的方式来进行显示,譬如文字,如果你没有在css中指定颜色,那么浏览器将采用黑色或者系统颜色来显示,div或者其他元素的背景,如果在css中没有被指定,浏览器则将其设置为白色或者透明,等等其他未定义的样式均如此。所以有很多东西出现IE和FF显示不一样的根本原因在于它们的默认显示不一样,而这个默认样式该如何显示我知道在w3中有没有对应的标准来进行规定,因此对于这点也就别去怪罪IE了。
11.为什么FF下文本无法撑开容器的高度标准浏览器中固定高度值的容器是不会象IE6里那样被撑开的,
那我又想固定高度,又想能被撑开需要怎样设置呢?办法就是去掉height设置min-height:200px;这里为了照顾
不认识min-height的IE6可以这样定义:
{ height:auto!important; height:200px; min-height:200px; }
12.FireFox下如何使连续长字段自动换行众所周知IE中直接使用
word-wrap:break-word就可以 了,FF中合用js插入
的方法来处理
type="text/javascrīpt">
function toBreakWord(el,intLen){
var
obj=document.getElementByIdx_x(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.getElementByIdx_x &&
!document.all) toBreakWord("ff", 37);
各种浏览器兼容篡位的css样式写法的更多相关文章
- 在不同的浏览器使用不同的css样式,解决浏览器兼容问题
区别IE6与FF: background:orange; *background:blue; 区别IE6与IE7: background:green !import ...
- 如何让不同浏览器调用不同的CSS样式
如何让不同浏览器调用不同的CSS样式 由 于对W3C标准支持程度的不同,往往导致同一个CSS样式表在各种Web浏览器中的呈现大相径庭.以目前市场占有率最高的两个浏览器Microsoft Interne ...
- 如何根据不同的浏览器写不同的css样式达到兼容
做前端静态页面的时候总是发现,ie的兼容性很差,总会出点问题.然后就去改代码 ,改完以后 又发现 火狐 谷歌又挂了,这可咋整. 后来发现做个判断吧 哪里有问题哪里就做个判断呗 ,咋判断呢,这么 ...
- 浏览器兼容汇总(css+js)
JavaScript 1. HTML对象获取问题 FireFox:document.getElementById("idName");ie:document.idname或者d ...
- 最全的CSS浏览器兼容问题【CSS技巧 】
CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理方法并整理了一下.对于web2.0的过度,请尽量用xhtml格 ...
- 解决浏览器兼容问题的css hack
原理 由于不同的浏览器对CSS的支持及解析结果不一样,还由于CSS中的优先级的关系.我们就可以根据这个来针对不同的浏览器来写不同的CSS.CSS Hack大致有3种表现形式,CSS类内部Hack.选择 ...
- 基于bootstrap框架在ie8以下,兼容媒体查询[css样式]
<style type="text/css"> /*基于bootstrap框架在ie8以下,兼容媒体查询*/ .row [class^="col-" ...
- 怎样使一个宽为200px和高为200px的层垂直居中于浏览器中?写出CSS样式代码。
div{ height:100px; width:100px; position:absolute; top:50%; width:50%; margin-letf:-100px; margin-to ...
- CSS3与页面布局学习总结(八)——浏览器兼容与前端性能优化
一.浏览器兼容 1.1.概要 世界上没有任何一个浏览器是一样的,同样的代码在不一样的浏览器上运行就存在兼容性问题.不同浏览器其内核亦不尽相同,相同内核的版本不同,相同版本的内核浏览器品牌不一样,各种运 ...
随机推荐
- MFC修改任务栏图标及程序运行exe图标
修改左上角的图标和任务栏里图标 在对话框构造函数中 1 CTestDlg::CTestDlg(CWnd* pParent )2 : CDialog(CTestDlg::IDD, pParent)3 { ...
- cf472C Design Tutorial: Make It Nondeterministic
C. Design Tutorial: Make It Nondeterministic time limit per test 2 seconds memory limit per test 256 ...
- java 常用的验证方法帮助类
import java.text.ParseException; import java.util.Collection; import java.util.Map; /** * 常用的验证方法帮助类 ...
- Android性能优化典范【转】
2015年伊始,Google发布了关于Android性能优化典范的专题,一共16个短视频,每个3-5分钟,帮助开发者创建更快更优秀的Android App.课程专题不仅仅介绍了Android系统中有关 ...
- easyui 表单验证validatetype——支持自定义验证
easyui 的validatebox()提供了自定义验证的方法,为此我把一些常用的数据验证汇总了一下,代码如下: 代码 Code highlighting produced by Actipro C ...
- 【转】【漫画解读】HDFS存储原理
根据Maneesh Varshney的漫画改编,以简洁易懂的漫画形式讲解HDFS存储机制与运行原理. 一.角色出演 如上图所示,HDFS存储相关角色与功能如下: Client:客户端,系统使用者,调用 ...
- poj 3728 The merchant(LCA)
Description There are N cities in a country, and there is one and only one simple path between each ...
- base_local_planner vs. dwa_planner
http://answers.ros.org/question/10718/dwa_planner-vs-base_local_planner/ The dwa_local_planner suppo ...
- JavaScript 运行机制详解:深入理解Event Loop
Philip Roberts的演讲<Help, I'm stuck in an event-loop>,详细.完整.正确地描述JavaScript引擎的内部运行机制. 一.为什么JavaS ...
- Android应用程序组件Content Provider的启动过程源代码分析
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6963418 通过前面的学习,我们知道在Andr ...