谷歌浏览器的识别
@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.概要 世界上没有任何一个浏览器是一样的,同样的代码在不一样的浏览器上运行就存在兼容性问题.不同浏览器其内核亦不尽相同,相同内核的版本不同,相同版本的内核浏览器品牌不一样,各种运 ...
随机推荐
-
MySQL函数
MySQL数据库提供了很多函数包括: 数学函数: 字符串函数: 日期和时间函数: 条件判断函数: 系统信息函数: 加密函数: 格式化函数: 一.数学函数 数学函数主要用于处理数字,包括整型.浮点数等. ...
-
【BZOJ-1042】硬币购物 容斥原理 + 完全背包
1042: [HAOI2008]硬币购物 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1811 Solved: 1057[Submit][Stat ...
-
剑指offer--面试题5
到现在为止,看过的书+代码有一定量了,并且也参加了个比赛,给自己的总体感觉:编程需要的是灵活的头脑,书里的东西只是讲个规则.思想,其实际实现可以千差万别! 潜在的规则+灵活的思维 = 程序! 在做 ...
-
C++虚函数表原理
C++中的虚函数的作用主要是实现了多态的机制.关于多态,简而言之就是用父类型别的指针指 向其子类的实例,然后通过父类的指针调用实际子类的成员函数.这种技术可以让父类的指针有“多种形态”,这是一种泛型技 ...
-
如何提取出ppt中的文字?
最近在看一位老师的教学视频,视频里大部分的知识都记录在ppt里,于是很想将ppt中的文字提取出来,如果我一页一页地粘贴复制的话,效率低到吓人,因为一章的ppt有130多页,于是在网上搜索了一下方法,与 ...
-
单选按钮易忽略的Group属性
Group就其意思就是一组的意思.就是说用于选择多个控件组合,选了TRUE后,你就可以为这组新建一个变量.把一组控件当一个控件来使用.例如多个单选按钮用group属性,这样你就可以用一个变量来管理这些 ...
-
Android高仿qq及微信底部菜单的几种实现方式
最近项目没那么忙,想着开发app的话,有很多都是重复,既然是重复的,那就没有必要每次都去写,所以就想着写一个app通用的基本框架,这里说的框架不是什么MVC,MVP,MVVM这种,而是app开发的通用 ...
-
Linux系统——程序员跳槽必备
相信在看这篇文章的你,曾经或者现在是否跳槽呢,在北上广一线城市,你是否还在挣着那可怜巴巴的工资,过着拮据生活呢?但是自己想跳槽,却没有一技之长或者是自己的技术找工作太难了,那么我建议你学习下linux ...
-
mac安全与隐私只有两个选项,少了一个任何来源
很多软件安装后就会出现,程序已损坏,请移到废纸篓的提示. 解决方法:在终端里输入:sudo spctl --master-disable 然后回车,然后输入密码,即可在安全选项中看到重新出现的允许任何 ...
-
restful知识点之五解析器_响应器_分页器
解析器 request.post:当数据时content-type urlencoded类型时才有数据 当content-type:是formdata时需要从request.body里取数据 requ ...