各种浏览器兼容篡位的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.概要 世界上没有任何一个浏览器是一样的,同样的代码在不一样的浏览器上运行就存在兼容性问题.不同浏览器其内核亦不尽相同,相同内核的版本不同,相同版本的内核浏览器品牌不一样,各种运 ...
随机推荐
- 【POJ 1236 Network of Schools】强联通分量问题 Tarjan算法,缩点
题目链接:http://poj.org/problem?id=1236 题意:给定一个表示n所学校网络连通关系的有向图.现要通过网络分发软件,规则是:若顶点u,v存在通路,发给u,则v可以通过网络从u ...
- CDH 2、Cloudera Manager的安装
1.Cloudera Manager • Cloudera Manager是一个管理CDH的端到端的应用. • 作用: – 管理 – 监控 – 诊断 – 集成 • 架构 • Server – 管理控制 ...
- background-position 使用方法具体介绍
语法: background-position : length || length background-position : position || position 取值: length : ...
- 对‘pthread_create’未定义的引用
由于pthread库不是Linux系统默认的库,连接时需要使用库libpthread.a,所以在使用pthread_create创建线程时,在编译中要加-l pthread参数: gcc exampl ...
- 为net-snmp添加读readTimeTicks
function readTimeTicks(time){ if(time === 0) return ''; var d = 0, h = 0, m = 0, s = 0; d = parseInt ...
- [Effective Modern C++] Item 3. Understand decltype - 了解decltype
条款三 了解decltype 基础知识 提供一个变量或者表达式,decltype会返回其类型,但是返回的内容会使人感到奇怪. 以下是一些简单的推断类型: ; // decltype(i) -> ...
- Ubuntu Server 安装部署 Cacti 服务器监控
本文的英文版本链接是 http://xuri.me/2013/10/20/install-the-cacti-server-monitor-on-ubuntu-server.html Cacti是一套 ...
- 发现一个不错的学习git的地方
Git入门:http://rogerdudler.github.io/git-guide/index.zh.html 简洁.实用.高效的学习git基本操作的方式
- 关于left join连接查询 两张表里有同名字段的问题
左连接查询在开发中很常用,但有个问题常常会遇到,两个表中有同名字段时,比如左右表都有一个id字段,会造成查询结果中左表的id值被右表的id值覆盖掉(大部分php框架都是这个效果),而且还不会报错,容易 ...
- windows程序设计读书笔记2——字符显示1
本程序使用GetSystemMetrics获取windows各种图像选项,并输出字符到窗口中. #define WINVER 0x0500 #include <windows.h> #in ...