美文网首页
浏览器兼容问题

浏览器兼容问题

作者: 怎么昵称 | 来源:发表于2017-07-20 12:11 被阅读0次
什么是 CSS hack

CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不同的CSS样式的目的,
比如.kwstu{width:300px;_width:200px;},一般浏览器会先给元素使用width:300px;的样式,紧接着后面还有个_width:200px;由于下划线_width只有IE6可以识别,所以此样式在IE6中实际设置对象的宽度为200px,后面的把前面的给覆盖了,而其他浏览器不识别_width不会执行_width:200px;这句样式,所以在其他浏览器中设置对象的宽度就是300px;

CSS hack由于不同厂商的浏览器,比如Internet Explorer,Safari,Mozilla Firefox,Chrome等,或者是同一厂商的浏览器的不同版本,如IE6和IE7,对CSS的解析认识不完全一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。 这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。
简单的说,CSS hack的目的就是使你的CSS代码兼容不同的浏览器。当然,我们也可以反过来利用CSS hack为不同版本的浏览器定制编写不同的CSS效果。

注意: 我们通常主要考虑的浏览器有IE6、IE7、IE8、谷歌浏览器(chrome)、火狐(Mozilla Firefox)即可,至于我们常用的傲游、QQ的TT浏览器是用你计算机中装的系统自带浏览器的内核,所以只需要兼容以上浏览器即可兼容TT傲游浏览器。

CSS hack用来解决有些css属性在不同浏览器中显示的效果不一样的问题。
CSS Hack一般都是利用各浏览器的支持CSS的能力和BUG来进行的。
所以对浏览器的选择大致可以分为能力选择和怪癖选择(BUG)。
能力通常是指浏览器对CSS特性的支持程度,
而怪癖是指浏览器特有的一些BUG。

友情提示:尽量找到通用方法而减少对CSS Hack的使用,大规模使用CSS Hack会带来维护成本的提高以及浏览器版本变化而带来类似Hack失效等系列问题。

CSS Hack常见的有三种形式:
CSS属性Hack、CSS选择符Hack以及IE条件注释Hack,
Hack主要针对IE浏览器。

1、属性级Hack:比如IE6能识别下划线“”和星号“”,
IE7能识别星号“
”,但不能识别下划线”
”,
而firefox两个都不能认识。
2、选择符级Hack:比如IE6能识别html .class{}
,IE7能识别
+html .class{}
或者*:first-child+html .class{}

3、IE条件注释Hack:IE条件注释是微软IE5开始就提供的一种非标准逻辑语句。
,这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效。

PS:条件注释只有在IE浏览器下才能执行,这个代码在非IE浏览下被当做注释视而不见。
可以通过IE条件注释载入不同的CSSJSHTML服务器代码等。

参考文章

谈一谈浏览器兼容的思路

(1) 要不要兼容 ? 从受众和产品角度考虑
(2)如果要兼容,是兼容到什么程度,
哪些浏览器兼容哪些效果?
(3)如何做?
根据兼容需求选择技术框架或库(JQuery)
根据兼容需求选择兼容工具:
html5shivRespond.jsCSS Resetnormalize.cssModernizr.jspostcss
条件注释、CSS Hack、js 能力检测做一些修补
优雅降级或 渐进增强

参考文章

列举5种以上浏览器兼容的写法

注意书写顺序

CSS属性前缀法
.topbar{
background: red; /firefox/
background: blue; / ie6 7/
_background: green; /
ie6识别*/
}

选择器前缀法
.class{} / ie6*/

+.class{} /ie7*/

IE条件注释 ,ie浏览器能识别

相关文章

  • 浏览器兼容

    什么是浏览器兼容问题 为什么会有浏览器兼容问题 用到的网站 处理兼容问题的思路 渐进增强和优雅降级 stackov...

  • 常见浏览器兼容问题及解决

    一、什么是浏览器兼容问题所谓浏览器兼容问题就是指不同浏览器或同种浏览器不同版本对相同代码解析效果不同,浏览器兼容问...

  • 浏览器兼容

    为何会有浏览器兼容问题 因为市场上的浏览器有很多,不同的浏览器内核对网页的解析存在差异,这也是导致浏览器兼容问题出...

  • 浏览器兼容

    1. 概要 什么是浏览器兼容问题? 同一份代码,有的浏览器效果正常,有的不正常 为什么会有浏览器兼容问题 同一产品...

  • 浏览器兼容相关概念

    什么是浏览器兼容问题?为什么会有浏览器兼容问题? 同一份代码,有的浏览器效果正常,有的不正常 同一产品,版本越老 ...

  • 浏览器兼容

    什么是浏览器兼容问题 同一份代码,有的浏览器效果正常,有的不正常 为什么会有浏览器兼容问题 同一产品,版本越老 b...

  • Browser Hack整理

    浏览器的兼容问题 1.浏览器内核:Mozilla Firefox ( Gecko )Internet Explor...

  • 盒模型 IE与W3C

    ![Uploading image_302998.png . . .] 浏览器兼容问题 由于IE浏览器使用自己的非...

  • 浏览器能力检测

    浏览器的兼容问题是前端开发避不开的一个问题,我们在处理浏览器兼容问题时,可以采取第三方插件来做兼容,或者是浏览器能...

  • Html引用实现不同浏览器兼容问题

    Html引用实现不同浏览器兼容问题 在head部分插入即可

网友评论

      本文标题:浏览器兼容问题

      本文链接:https://www.haomeiwen.com/subject/xzddkxtx.html