搜索

查看: 3089|回复: 11

[CSS/HTML] CSS hack用法案例详解

[复制链接]
发表于 2023-5-4 16:46:18 | 显示全部楼层 |阅读模式
Editor 2023-5-4 16:46:18 3089 11 看全部
之前一直很狭隘的对CSS hack持有偏见,觉得写得规范的代码不应该使用这些“邪门歪道”,可最近产品发布一个小问题却让我头疼了很久,最后查了一下资料,竟然使用CSS hack轻松解决了,不得不服啊,对付神奇的IE就得使用这些利器。
什么是CSS hack
由于不同的浏览器,甚至同一浏览器的不同版本对CSS的解析认识不一样,导致生成的页面效果不一致,写出针对不同浏览器CSS code就称为CSS hack。
常用的CSS hack 有三种方式,CSS 内部hack、选择器hack、HTML 头部引用,其中第一种最常用。
CSS 内部hack
正经的CSS是这么写的


   
        Test
        
            .test
            {
                background-color:green;
            }
        
   
   
        
   


这样的代码对于所有当前常用的浏览器都是好使的,结果应该是这样子的

202101231661.png

202101231661.png


但是在CSS3中常见一些这样的写法

/*Mozilla内核浏览器:firefox3.5+*/
  -moz-transform: rotate | scale | skew | translate ;
/*Webkit内核浏览器:Safari and Chrome*/
  -webkit-transform: rotate | scale | skew | translate ;
/*Opera*/
  -o-transform: rotate | scale | skew | translate ;
/*IE9*/
  -ms-transform: rotate | scale | skew | translate ;
/*W3C标准*/
  transform: rotate | scale | skew | translate ;
如果没有注释乍一看还以为逆天了,这样的代码都好使!这样的代码确实好使,CSS3目前标准还没有统一,各个浏览器都有自己的表现方式,甚至有的实现,有的未实现,在前面加一些前缀以表示支持某个特定浏览器,这也是CSS 内部hack的基本原理,向上面这些简单易懂,但是真正的CSS hack 远远不止于此,因为有不死的IE6及其各种奇葩的兄弟版本。
CSS 内部hack 语法是这样的 selector{?property:value?;} ,上面代码所示的是在属性名称之前的hack,当然还有这样的

*background-color:green;
属性前面加个“*”这样的写法只会对IE6、7生效,其它版本IE及现代浏览器会忽略这条指令(没有特殊说明,本文所有hack都是指在声明了DOCTYPE的文档的效果)

-background-color:green;
属性前面有个“-”这样的只有IE6识别,还有些在后面的hack

background-color:green!important;
这样在属性值后面添加“!important”的写法只有IE6不能识别,其它版本IE及现代浏览器都可以识别,还有“+”、“\0”、”\9” 等,乱七八糟好烦,画个表

202101231662.png

202101231662.png


这样就清楚多了吧。如果只想给上面的test DIV在IE访问的时候加绿色背景,就可以这么写

background-color:green\9;
如果想IE6红色,IE7绿色,其它黄色(当然没人这么无聊)就可以这么写

background-color:green; +background-color:green; _background-color:green;
选择器hack
选择器hanck主要是针对IE浏览器,其实并不怎么常用,语法是这样的: selector{ sRules }

202101231663.png

202101231663.png



:root .test
{
    background-color:green;
}
HTML头部引用
HTML头部引用就比较特殊了,类似于程序语句,只能使用在HTML文件里,而不能在CSS文件中使用,并且只有在IE浏览器下才能执行,这个代码在非IE浏览下非单不是执行该条件下的定义,而是当做注释视而不见。







lte:就是Less than or equal to的简写,也就是小于或等于的意思。
lt :就是Less than的简写,也就是小于的意思。
gte:就是Greater than or equal to的简写,也就是大于或等于的意思。
gt :就是Greater than的简写,也就是大于的意思。
! :就是不等于的意思,跟javascript里的不等于判断符相同。
书写顺序
看看,看看,这么多姿势,那么一个效果,好多种写法,什么顺序写才能保证各个浏览器都得到希望的效果呢?因为CSS只要是同一级别,出现重复属性设置,后出现的会覆盖前面出现的,所以在书写的时候一般把识别能力强的写前面,看个例子

_background-color:red;
background-color:green;

如果希望DIV在IE6上是红色,其它是绿色,上面的写法可不可以呢?试一下发现所有浏览器上都是绿色,因为在IE6解析的时候,第一句能够识别,背景设为红色,但是第二句所有浏览器都识别,IE6也不例外,背景颜色又被设为绿色,所以得反过来写

background-color:green;
_background-color:red;
总结出的规律就是:先一般,再特殊。有兴趣的同学可以试试试试下面CSS,看看和你想的效果是否一样

background-color:blue; /*所有浏览器*/
background-color:red\9;/*所有的ie*/
background-color:yellow\0; /* ie8+*/
+background-color:pink; /*+ ie7*/

到此这篇关于CSS hack用法案例详解的文章就介绍到这了,更多相关CSS hack用法内容请搜索知鸟论坛以前的文章或继续浏览下面的相关文章希望大家以后多多支持知鸟论坛
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-28 21:53:56 | 显示全部楼层
心随674 2023-6-28 21:53:56 看全部
感谢楼主的无私分享!要想知鸟论坛好 就靠你我他
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-29 02:59:16 | 显示全部楼层
永远就三年疗 2023-6-29 02:59:16 看全部
这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-29 10:18:03 | 显示全部楼层
123456848 2023-6-29 10:18:03 看全部
我看不错噢 谢谢楼主!知鸟论坛越来越好!
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-29 14:05:56 | 显示全部楼层
当当当当裤裆坦 2023-6-29 14:05:56 看全部
论坛不能没有像楼主这样的人才啊!我会一直支持知鸟论坛
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-29 19:02:46 | 显示全部楼层
向往草原403 2023-6-29 19:02:46 看全部
感谢楼主的无私分享!要想知鸟论坛好 就靠你我他
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-30 00:39:48 | 显示全部楼层
丁侦球 2023-6-30 00:39:48 看全部
这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-30 04:20:18 | 显示全部楼层
冀苍鸾 2023-6-30 04:20:18 看全部
这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-30 09:51:21 | 显示全部楼层
尘埃416 2023-6-30 09:51:21 看全部
楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

发表于 2023-6-30 22:05:24 | 显示全部楼层
幸福341 2023-6-30 22:05:24 看全部
既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
知鸟论坛永久地址发布页:www.zn60.me
回复

使用道具 举报

  • 您可能感兴趣
点击右侧快捷回复 【请勿灌水】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 返回列表

RSS订阅| SiteMap| 小黑屋| 赞兔论坛
联系邮箱E-mail:zniao@foxmail.com
快速回复 返回顶部 返回列表