怎么样能写出兼容多个浏览器的css(主流浏览器css兼容问题汇总)
怎么样能写出兼容多个浏览器的css
主流浏览器css兼容问题汇总现在就post一些做兼容的总结,可能不够全面,但是可以告诉大家如何避过一些坑。主要测试了chrome,firefox,ie8、9、11,360浏览器。
一、基本的css兼容:
1、可能很多人喜欢用css hack的形式去兼容ie浏览器,但是我自己用起来感觉其实不好使 。ie7-就不考虑了,问题在哪呢,就在ie8的甑别上,你怎么让样式只对ie8起作用。上网搜你可能会得到这样的答案:
- .selector {
- color: #ff0\0;/*ie8*/
- color: #f00\9\0;/*ie9+*/
- }
但是实际上你一试就嗝屁了,因为ie8他就是识别ie9能识别的,所以根本不能让独立的样式只对ie8起作用。
更好用的是什么呢,是用ie浏览器独有的文档注释的方式。像这样:
- <!DOCTYPE html>
- <!--[if IE 8 ]> <html class="ie8" lang="en"> <![endif]-->
- <!--[if IE 9 ]> <html class="ie9" lang="en"> <![endif]-->
- <!--[if (gt IE 9)|!(IE)]><!-->
- <html lang="en"> <!--<![endif]-->
屡试不爽,关键是可以独立的维护处理兼容ie浏览器的样式表,又不会淹没在一大堆css hack标识中,只需要在独立对ie8应用样式规则的地方,copy该条规则,然后在前面加上 .ie8然后就能随便写了,对付ie9也一样。
2、对于360双核这种找抽浏览器,据说添加以下头部meta信息可以使得网页用webkit内核渲染:
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
IE=edge:保持使用最高级别模式显示内容;
chrome=1:谷歌的外挂插件Google Chrome Frame(谷歌内嵌浏览器框架GCF),使用IE浏览网页时实际上是使用Chrome浏览器内核渲染,最低支持IE6,但前提是客户端已经安装GCF。
但实际上这个meta标识是ie浏览器所识别的(详情:ies-compatibility-features-for-site-developers/),并不是公认的标准,所以用双核的浏览器会傲娇。当然360也会傲娇,所以有时你会发现360并不能总是(也可能是我本人rp差)以chrome内核渲染你的按现代标准开发的网页。
那么试试这个吧,添加:<meta name="renderer" content="webkit">
这个meta标识是360自家实现的(详情:meta.html),表示强制要求360这造福中国社会万千网民的浏览器用chrome的内核渲染网页。
ok,一行代码搞定360绝大部分的兼容。
二、ie8的css兼容
现在说说ie8下的css问题:
1、ie8支持:first-child,但不支持:last-child。因为前者是css2.1标准,后者是css3标准。参下:
CSS 2.1 selectors:Basic CSS selectors including: * (universal selector), > (child selector), :first-child, :link, :visited, :active, :hover, :focus, :lang(), + (adjacent sibling selector), [attr], [attr="val"], [attr~="val"], [attr|="bar"], .foo (class selector), #foo (id selector)
2、 为什么会发现上面的奇怪的东西(怪我css2.1和css3分不清),因为编译sass文件后发现ie8下的样式基本全歇菜了。需要注意的是,如果浏览器 不支持的选择器和支持的选择器写在一起,那么整条规则就不起作用了。比如你不小心创造了一个伪元素(是真的伪哦).bb:bb-child, .cc{background:#333;}那么这整条规则就不起作用了,所有浏览器在此情况下都会歇菜,.cc的样式就丢失了。
3、 input设置了左右padding,but输入较多内容时padding还是会消失。这个问题是无解的,ie浏览器她就是这么渲染input的,解决方法是在input 外面套一层li,用li设置左右padding,border,width和height,input只需要设置width和weight为100% 即可。另外,正常来讲,如果没有明确设置height的值,那么设置的line-height值就是height的值,but对于ie8,如果input 设置了 line-height,那么input必须设置height,否则input的内容显示有问题,会上下隐藏部分内容,她就是要躲猫猫。
4、 为什么上面我不用input的伪元素进行设置而要嵌套多一层li呢?因为input,img,iframe等元素不支持伪元素 -_-||。:before 和:after伪元素指定了一个元素文档树内容之前和之后的内容。与'content'属性联用,指定了插入的内容(也就是你必须显性设置content 属性这两个伪家伙才能在文档中显示出来,哪怕设置content属性为空字符串也行)。作为DOM元素,伪元素都是在容器内进行渲染的, input,img,iframe等元素都不能包含其他元素,也就是不是容器,所以不能通过伪元素插入内容。
5、 table中如果不是严格的用于表格,而是用于奇葩的局部布局时(我也想问为什么用来布局。。),td设置成inline-block可以排成一行,但是 ie8和ie9 下,如果td中的内容很长,即使td设置了宽度,td也会撑开并占用td设置的margin(废话,td是没有margin可言的),直到挤占所有的td 宽度之和为tr的宽度。但是td设置成float:left;就能表现成block。这个不清楚为什么,但是管用。。
6、父元素的左padding会和子元素的左margin重叠。这个是没有好好实现盒子模型的事情了,包容吧。。
7、sprite图中的icons之间最好留空白间隔,哪怕间隔1px也好,否则ie8下会出现使用了某一个icon当背景,icon后面跟着的其他icon也顺带显示了一小部分的bug,所以icons之间还是要适当留白,不要太省。
三、ie11部分css问题
1、 ie11下很多元素表现和其他浏览器不一致,比如对应用了同一样式(不设置 高度)的li,其他浏览器解析的高度是一致的,但是ie11下该li有可能高度偏大,由此导致一些排版上的问题,所以,如果发现元素排版上下偏移的问题,查看此元素或其当代元素是否设置了高度,统一添上高度一切都ok了。
2、抱歉,ie11问题确实不多。
四、结尾附上一个关于css优先级的奇谈
首先我们知道:
1、id选择器优先级权重比class选择器大一个数量级,class选择器权重比标签选择器大一个数量级;
2、class选择器和属性选择器同优先级;
3、样式的优先程度需要根据第1条规则计算整体的优先级,按选择器权重计算各条样式规则中所有选择器优先级之和,哪条规则权重大,那条就说了算。如果相同那么后面的覆盖前面的。
4、像这种.dog > p开挂,多了特殊符号的,并不会增加优势,还是和 .dog p优先级一样。
然后可以抛出一个问题了:
对于下面的文档结构,分别对 p | .p | li p | .parent | #parent设置color属性,那么优先级如何呢?
- <li id="parent" class="parent">
- <p class="p">p</p>
- </li>
结果很有意思:
也就是 .p > li p > p > #parent > .parent
id选择器居然比p选择器优先级还低!将p元素和li元素分开看,.p > li p > p 很正常, #parent > .parent也很正常。所以问题关键在子级p和父级#parent, 子级的选择器优先级比父级的选择器优先级高,或者说继承的优先级程度比自身的优先级低!
嵌套多一层看看就知道是不是了,分别对#parent | li | p设置color属性:
结果确实是p > li > #parent:
即使应用两个选择器也无济于事,依然是p >#parent li
但是只要能定位到p元素,那么父级选择器的权重就起作用了,一试便知,对#parent p | #p 设置同样的样式结果是这样的:
嗯,确实如此。所以:
5、css样式优先级还和继承有关,继承的优先级不如本身应用的优先级高。
以上就是本文的全部内容,希望对大家的学习有所帮助。
原文:http://www.cnblogs.com/suspiderweb/p/5277540.html
- 前端pc适配方案(前端兼容性问题总结PC端)
- python3和python2 兼容(Python2和Python3的共存和切换使用)
- cssdiv垂直居中怎么设置(CSS设置DIV垂直居中的N种方法 兼容IE浏览器)
- html5文档的基本结构及必要的注释(关于HTML5+ API plusready的兼容问题)
- base64图片在各种浏览器的兼容性处理(base64图片在各种浏览器的兼容性处理)
- thinkphp兼容dedecms(DedeCMS Error:Tag disabled:"php"的解决办法)
- html5video怎么优化(html5 移动端视频video的android兼容去除播放控件、全屏)
- 如何检查css 兼容性(CSS浏览器兼容性常见问题总结大全推荐)
- dedecms兼容模式(DedeCMS 验证码不正确的解决方法php配置问题)
- placeholder兼容性
- css的五种基本选择器(CSS兼容问题之HACK技术)
- css样式功能表能兼容所有浏览器吗(比较全的CSS浏览器兼容问题整理总结)
- css中设置flex布局浮动是否会生效(深入理解CSS系列之flex兼容)
- 如何彻底关闭vmwareworkstation(关于vmware workstations与device/credential不兼容启动报错的问题)
- ie浏览器css颜色兼容(IE8的css hack9 使用说明)
- python3.7不兼容pywinauto(浅谈python编译pyc工程--导包问题解决)
- 你只要花上20天记单词,英语成绩就能从57提到100(你只要花上20天记单词)
- 夕云天际飞,亢龙化太极(夕云天际飞亢龙化太极)
- 爱情可以当饭吃吗(怎么回复)
- 高考数学题(高考数学题基础题占多少分)
- 没钱只能吃土(没钱要吃土了幽默短信发朋友圈)
- 今年考高会很难吗(今年高考会考试吗)
热门推荐
- Linux ls命令的使用(Linux ls命令的使用)
- mysql哪个版本可以下载msi(新手必备之MySQL msi版本下载安装图文详细教程)
- php 各类商品结算算法(PHP实现财务审核通过后返现金额到客户的功能)
- python数字形式转换详解(Python3.5实现的罗马数字转换成整数功能示例)
- amaze ui使用教程(Amaze UI 文件选择域的示例代码)
- mysql怎么建立主键外键(mysql 实现设置多个主键的操作)
- extjs checkboxGroup 复选框的用法
- mysql缓存是什么(详解mysql查询缓存简单使用)
- html如何给table加边框(HTML table 表格边框的实现思路)
- iis搭建web服务器和ftp教程(Windows实例通过IIS如何搭建多个FTP站点?)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9