我的编程空间,编程开发者的网络收藏夹
学习永远不晚

CSS hack的知识有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

CSS hack的知识有哪些

这篇文章主要介绍“CSS hack的知识有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CSS hack的知识有哪些”文章能帮助大家解决问题。

    什么是CSShack

    CSShack由于不同的浏览器,比如IE6,IE7,Firefox等,对CSS的解析认识不一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。

    CSShack分类

    hack主要分为CSS选择器hack、CSS属性hack、IE条件注释hack。

    CSS选择器hack:比如IE6能识别*html.class{},IE7能识别*+html.class{}或者*:first-child+html.class{}等。

    CSS属性hack:比如IE6能识别下划线"_"和星号"*",IE7能识别星号"*",但不能识别下划线"_",而firefox两个都不能认识等。

    IE条件注释hack:

    针对所有IE:<!--[ifIE]><!--您的代码--><![endif]-->

    针对IE6及以下版本:<!--[ifltIE7]><!--您的代码--><![endif]-->

    这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效。

    书写顺序,一般是将识别能力强的浏览器的CSS写在前面。

    用法

    比如要分辨IE6和firefox两种浏览器,可以这样写:

    div{

    background:green;

    *background:red;(bothIE6&&IE7)

    }

    可以看到在IE6中看到是红色的,在firefox中看到是绿色的。

    在firefox中,它是识别不了后面的那个带星号的东西是什么的,于是将它过滤掉,解析得到的结果是:div{background:green},于是理所当然这个div的背景是绿色的。

    在IE6中,它两个background都能识别出来,它解析得到的结果是:div{background:green;background:red;},于是根据优先级别,处在后面的red的优先级高,于是当然这个div的背景颜色就是红色的了。

    浏览器识别

    <!DOCTYPEhtml>

    <html>

    <head>

    <title>CssHack</title>

    <style>

    #test

    {

    width:300px;

    height:300px;

    background-color:blue;

    background-color:red\9;

    background-color:yellow\0;

    +background-color:pink;

    _background-color:orange;

    }

    :root#test{background-color:purple\9;}

    @mediaalland(min-width:0px){#test{background-color:black\0;}}

    @mediascreenand(-webkit-min-device-pixel-ratio:0){#test{background-color:gray;}}

    </style>

    </head>

    <body>

    <divid="test">test</div>

    </body>

    </html>

    上面这段代码大家可以直接copy出来,保存成html在各浏览器试试。分析:

    (1)background-color:blue;各个浏览器都认识,这里给firefox用;

    (2)background-color:red\9;\9所有的ie浏览器可识别;

    (3)background-color:yellow\0;\0是留给ie8的,但笔者测试,发现最新版opera也认识,汗。。。不过且慢,后面自有hack写了给opera认的,所以,\0我们就认为是给ie8留的;

    (4)+background-color:pink;+ie7定了;

    (5)_background-color:orange;_专门留给神奇的ie6;

    (6):root#test{background-color:purple\9;}:root是给ie9的,网上流传了个版本是:root#test{background-color:purple\0;},新版opera也认识,所以经笔者反复验证最终ie9特有的为:root选择符{属性\9;}

    (7)@mediaalland(min-width:0px){#test{background-color:black\0;}}这个是老是跟ie抢着认\0的神奇的opera,必须加个\0,不然firefox,chrome,safari也都认识。。。

    (8)@mediascreenand(-webkit-min-device-pixel-ratio:0){#test{background-color:gray;}}最后这个是浏览器新贵chrome和safari的。

关于“CSS hack的知识有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

CSS hack的知识有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

CSS的背景知识点有哪些

本篇内容主要讲解“CSS的背景知识点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS的背景知识点有哪些”吧!介绍CSS background属性是以下属性的简写。背景剪辑,背景颜色,背
2023-06-27

CSS的基础知识点有哪些

这篇文章主要介绍“CSS的基础知识点有哪些”,在日常操作中,相信很多人在CSS的基础知识点有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS的基础知识点有哪些”的疑惑有所帮助!接下来,请跟着小编一起来
2023-06-27

css前端知识点有哪些

本篇文章给大家分享的是有关css前端知识点有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、css的概念:(CascadingStyleSheet级联样式表)优点:1.内
2023-06-08

编程热搜

目录