欢迎光临 - 我的站长站,本站所有资源仅供学习与参考,禁止用于商业用途或从事违法行为!

css教程

回味CSS hack的几种常用写法

css教程 我的站长站 2020-10-13 共80人阅读

随着浏览器版本越来越完善,现在前端开发使用到CSS hack的机会基本很少了,但是作为专业前端开发工程师,还是有必要了解CSS hack的,我的站长站今天带大家回味下以往的CSS hack常用方法。

什么是CSS hack

由于不同的浏览器,甚至同一浏览器的不同版本对CSS的解析认识不一样,导致生成的页面效果不一致,写出针对不同浏览器CSS code就称为CSS hack。

常用的CSS hack 有三种方式,CSS 内部hack、选择器hack、HTML 头部引用,其中第一种最常用。

CSS 内部hack

正经的CSS是这么写的

<!DOCTYPE html><html>
<head>
<title>Test</title>
<style type="text/css" >
.test            {
background-color:green;
}
</style>
</head>
<body>
<div class="test" style="height:100px; width:100px; line-height:100px; margin:50px; border:1px solid #000;"></div>
</body>
<html>

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

但是在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{<hack>?property:value<hack>?;} ,上面代码所示的是在属性名称之前的hack,当然还有这样的

*background-color:green;

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

-background-color:green;

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

background-color:green!important;

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

background-color:green9;

如果想IE6红色,IE7绿色,其它黄色(当然没人这么无聊)就可以这么写

background-color:green;
+background-color:green;
_background-color:green;

选择器hack

选择器hanck主要是针对IE浏览器,其实并不怎么常用,语法是这样的:<hack> selector{ sRules }

针对IE9的hack可以这么写

:root .test{
background-color:green;
}

HTML头部引用

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

<!– 默认先调用css.css样式表 –><link rel="stylesheet" type="text/css" href="css.css" /><!–[if IE 7]><!– 如果IE浏览器版是7,调用ie7.css样式表 –><link rel="stylesheet" type="text/css" href="ie7.css" /><![endif]–><!–[if lte IE 6]><!– 如果IE浏览器版本小于等于6,调用ie.css样式表 –><link rel="stylesheet" type="text/css" href="ie.css" /><![endif]–>

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:red9;/*所有的ie*/background-color:yellow; /* ie8+*/+background-color:pink; /*+ ie7*/


相关专题
css
css
2021-09-24 78

css是前端开发中的样式语言,学好CSS可以帮助开发出漂亮的模板,css专题为您整理本站所有css相关信息,包含css模板下载,css使用教程分享和css示例代码....

相关推荐
  • CSS语法
  • CSS选择器
  • CSS * 选择器

    在CSS中选择器中“*”,代表选择全部元素,我们通常用它来处理全部重置样式使用,其他地方很少使用了。语法语义选择全部元素,也可以选择另一个元素内的所有元素兼容性兼容所有浏览器语法代码示例*{padding:0px;margin:0px;}div *{background-color:yellow;...

    css教程 82 3年前
  • CSS文字超出省略号显示

    帝国CMS标题超出省略号显示可以用:<?=esub($bqr[title],32,'...')?> 但有的地方却不是标题,但也想实现文章超出省略号显示。这里给大家介绍的是利用CSS来达到效果。 HTM...

    css教程 333 10年前
  • CSS字间距样式语法教程

    做网站后,为了外观美观,我们可以通过CSS控制字间距。就是使用CSS的letter-spacing属性来控制。CSS写法:letter-spacing:10px;(后面字数是二字之间的间距值)举例:<style>p{letter-spacing:10px;}</style><p>段落文字段落文字段落文字</p>...

    css教程 192 4年前
  • CSS定位教程 position语法详解
    CSS定位教程 position语法详解

    CSS中的定位,用position语法方法,定位又分为绝对定位、相对定位和固定定位。position语法为CSS2版本,无继承性,默认值为:static。position语法语法:position:static | relative | absolute | fixed代码...

    css教程 85 3年前
  • CSS定位教程 z-index层级语法详解

    在CSS开发中需要某元素覆盖在另一元素的上面,就需要用到z-index语法。z-index语法需要搭配position使用,position语法看下面这篇教程。[xxid]70,1440[/xxid]z-index语法为CSS2版本,无继承性z-index语法z-index: auto | <integer>默认值:auto语法示例z-in...

    css教程 83 3年前
  • CSS如何选择第一个和倒数第一个元素

    前端新手会遇到不知道如何选择列表中的第一个和倒数第一个元素,其实这非常简单。以后所有关于CSS选择的问题,都可以直接搜索CSS选择器的手册,里面有所有的CSS选择解决方法。今天主要介绍CSS如何选择第一个和倒数第一个元素,这里就需要用到:first-child和...

    css教程 40 9个月前
  • CSS伪类选择符大全

    选择符版本简介E:linkCSS1设置超链接a在未被访问前的样式。E:visitedCSS1设置超链接a在其链接地址已被访问过时的样式。E:hoverCSS1/CSS2设置元素在其鼠标悬停时的样式。E:activeCSS1/CSS2设置元素在被用户激活(在鼠标点击与释放之间发生的事件)时的样...

    css教程 33 1年前
  • 前端开发如何使用其他字体(图文)

    我们经常看到别人的网站字体非常漂亮,那是因为他们使用了其他的美化字体,合理的使用字体可以让网站看上去,高端优雅。那么如何使用自己下载的字体,我的站长站今天分享给大家整套方法。1、字体选择选择字体要注意两点,如果这两点不注意,会适得其反的。一、...

    css教程 56 1年前
  • CSS3修改浏览器滚动条样式

    首先我们写一个简单的小实例来说明下,设置一个长框为300的div,设置下溢出滚动。<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv=&q...

    css教程 46 2年前
  • 为什么bootstrap国内很少人使用

    前言Bootstrap业内知名度很高,在刚刚出来的时候是史无前例的,虽说不少公司在招聘岗位中也要求掌握Bootstrap等框架,但现实项目中应用Bootstrap的并不多。随着更多优秀的前端框架的出现,bootstrap对比后就会发现很多缺点,前端er们自然而然的就放弃了使用bo...

    css教程 678 2年前