专栏首页知无涯前端必看!各大浏览器 CSS Hack 收集

前端必看!各大浏览器 CSS Hack 收集

1、什么是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指各版本及各品牌浏览器之间对CSS解释后出现网页内容的误差(比如我们常说错位)的处理。由于各浏览器的内核不同,所以会造成一些误差就像JS一样,一个JS网页特效,在微软IE6、IE7、IE8浏览器有效果,但可能在火狐(Mozilla Firefox)谷歌浏览器无效,这样就叫做JS hack ,所以我们对于CSS来说他们来解决各浏览器对CSS解释不同所采取的区别不同浏览器制作不同的CSS样式的设置来解决这些问题就叫作CSS Hack。

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

2、CSS hack解决问题

CSS hack用来解决有些css属性在不同浏览器中显示的效果不一样的问题,如margin属性在ie6中显示的距离会比其他浏览器中显示的距离宽2倍,也就是说margin-left:20px;在ie6中距左侧对象的实际显示距离是40px,而在非ie6中显示的距左侧对象的距离是设置的值20px;所以要想设置一个对象距离左侧对象的距离在所有浏览器中都显示是20px的宽度的样式应为:.kwstu{margin-left:20px;_margin-left:20px;}。

3、浏览器识别字符标准对应表

从上图可以分析出以下几种情况:

1.大部分特殊字符IE浏览器支持,其他主流浏览器firefox,chrome,opera,safari不支持 (opera可识别除外)。 2.9??? :所有IE浏览器都支持 3._和-? :仅IE6支持 4.*???? :IE6、E7支持 5.??? :IE8、IE9支持,opera部分支持 6.9? :IE8部分支持、IE9支持 7.9? :IE8、IE9支持

4、各种CSS hack情况介绍

1.区别IE和非IE浏览器

#tip{ background:blue; background:red9; }

2.区别IE6,IE7,IE8,FF

【区别符号】:“9”、“*”、“_”

#tip{ background:blue; background:red9; *background:black; _background:orange; }

【说明】:因为IE系列浏览器可读「9」,而IE6和IE7可读「*」(米字号),另外IE6可辨识「_」(底线),因此可以依照顺序写下来,就会让浏览器正确的读取到自己看得懂得CSS语法,所以就可以有效区分IE各版本和非IE浏览器(像是Firefox、Opera、GoogleChrome、Safari等)。

3.区别IE6、IE7、Firefox(方法1)

【区别符号】:“*”、“_”

#tip{ background:blue; *background:black; _background:orange; }

【说明】:IE7和IE6可读「*」(米字号),IE6又可以读「_」(底线),但是IE7却无法读取「_」,至于Firefox(非IE浏览器)则完全无法辨识「*」和「_」,因此就可以透过这样的差异性来区分IE6、IE7、Firefox

4.区别IE6、IE7、Firefox(方法2)

【区别符号】:“*”、“!important”

#tip{ background:blue; *background:green!important; *background:orange; }

【说明】:IE7可以辨识「*」和「!important」,但是IE6只可以辨识「*」,却无法辨识「!important」,至于Firefox可以读取「!important」但不能辨识「*」因此可以透过这样的差异来有效区隔IE6、IE7、Firefox。

5.区别IE7、Firefox

【区别符号】:“*”、“!important”

#tip{ background:blue; *background:green!important; }

【说明】:因为Firefox可以辨识「!important」但却无法辨识「*」,而IE7则可以同时看懂「*」、「!important」,因此可以两个辨识符号来区隔IE7和Firefox。

6.区别IE6、IE7(方法1)

【区别符号】:“*”、“_”

#tip{ *background:black; _background:orange; }

【说明】:IE7和IE6都可以辨识「*」(米字号),但IE6可以辨识「_」(底线),IE7却无法辨识,透过IE7无法读取「_」的特性就能轻鬆区隔IE6和IE7之间的差异。

7.区别IE6、IE7(方法2)

【区别符号】:“!important”

#tip{ background:black!important; background:orange; }

【说明】:因为IE7可读取「!important;」但IE6却不行,而CSS的读取步骤是从上到下,因此IE6读取时因无法辨识「!important」而直接跳到下一行读取CSS,所以背景色会呈现橘色。

8.区别IE6、Firefox

【区别符号】:“_”

#tip{ background:black; _background:orange; }

【说明】:因为IE6可以辨识「_」(底线),但是Firefox却不行,因此可以透过这样的差异来区隔Firefox和IE6,有效达成CSShack。

5、IE浏览器下hack总结

element{ color:#6669; //IE8 IE9 * color:#999;?? //IE7 _color:#EBEBEB; //IE6 }

可以看出,利用字符识别无法区分IE8和IE9,我们可以从伪类的识别来区分

element{ color:#6669;????? //IE8 * color:#999;??????? //IE7 _color:#EBEBEB;????? //IE6 } :root element{color:#6669;}//IE9

【说明】:“:root”伪类IE系列只有IE9支持,其他主流浏览器均支持,利用这一点来区分IE8和IE9。另外考虑到opera部分支持,完全支持:root,所以不使用。

6、其他主流浏览器css hack总结

1.Firefox浏览器:mozilla私有属性

@-moz-document url-prefix(){ .element{color:#f1f1f1;}} //Firefox

2.Webkit和Opera:

@media all and (min-width: 0px){ .element{color:#777;} } //Webkit @media screen and (-webkit-min-device-pixel-ratio:0) { .element{color:#444;} } //Opera @media all and (-webkit-min-device-pixel-ratio:10000), not all and (-webkit-min-device-pixel-ratio:0) { .element{color:#336699;} }

7、兼容各大主流浏览器(最新版本)css hack汇总如下(最全的):

.element{ color:#000;???????????? [;color:#f00;];???????? color:#6669;?????????? *color:#999;??????????? _color:#333;??????????? } :root .element{color:#0f09;}? @media all and (-webkit-min-device-pixel-ratio:10000), not all and ( -webkit-min-device-pixel-ratio:0) { .element{color:#336699;}}? @-moz-document url-prefix(){ .element{color:#f1f1f1;}}

8、建议:实际开发先如果不是很清楚可以先写布局代码,写一个阶段用浏览器测试工具(常用工具推荐IETEST)测试一个各个版本浏览器的布局效果,如有问题针对有问题的浏览器单独调试。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • PHP 实现访问HTTP时自动跳转至HTTPS

    落叶大大
  • Adobe PS快捷键

    落叶大大
  • ASP跨站提交参数检测

    落叶大大
  • Linux 当文件系统坏掉了该怎么整

    小手冰凉
  • WGCNA关键模块和hub基因筛选

    WGCNA的理论背景知识 WGCNA的详细分析流程 关键模块和hub基因筛选,在流程中并不可知 模块划分好后如何找到key module

    Y大宽
  • 计算机中的运算是如何产生的呢?

    比如当前要执行一个加法的运算,就发送一个加法指令给计算机,计算机的功能也就改变了。

    小明说前端
  • kvm虚拟机的四种网络模式

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

    suveng
  • 敏捷实践经验分享,企业如何在敏捷开发中实施DoD

    当你有两个或更多的人参与同一个事情的时候,我们的“团队”就产生了,这时我们最重要的事情,就是要设定和统一团队的期望值,在本文中,这就是“完成标准”。

    CORNERSTONE
  • 虚拟化平台cloudstack(3)——安装(下)

    登录时用户名和密码错误 默认账号密码 admin/password 管理节点安装好后,初始化数据库,完了使用admin和password登陆提示用户名密码错误...

    cloudskyme
  • pytorch维度变换-补充知识

    除了.t()方法外,还可以使用.transpose(d1, d2)函数。在使用时需要给d1

    用户6719124

扫码关注云+社区

领取腾讯云代金券