CSS怎么实现向下兼容
这篇文章主要介绍"CSS怎么实现向下兼容",在日常操作中,相信很多人在CSS怎么实现向下兼容问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"CSS怎么实现向下兼容"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
巧用浏览器CSS属性值实现向下兼容
CSS3中有很多好的特性,例如box-shadow
盒阴影,但是,唯一的问题是IE8浏览器不支持,如果是对外的PC站点,则IE8浏览器不可不顾,尤其一些受众广泛的网站。
怎么办呢?我的做法往往是这样,IE9+浏览器使用box-shadow
阴影,而IE7,IE8浏览器使用border
线框。
例如下面截图效果:
也就是针对不同浏览器采取不同的策略,我们一般最先的反应是采用一些CSS hack技巧,例如,我们这里,就是要区分IE9+浏览器和IE8-浏览器,这个其实不难,可以使用:root
伪类,在IE9+浏览器中,:root
实际上等同于html
,于是,我们都会这么做:
.box { border: 1px solid #ddd;}:root box { border: 0 none; box-shadow: 0 1px 3px rgba(0,0,0,.25);}
从功能上满足了我们的开发需求,大多数小伙伴此时就会到此为止。实际上,我们可以做的更好。
上面这种CSS hack技巧有一个比较大的问题,就是,当我们给IE9+浏览器使用不同的CSS声明的时候,不经意间,把这些CSS声明的权重给提高了。这很容易增加我们CSS代码的复杂度,例如,经常会遇到后面样式需要覆盖前面的,由于:root .box
提高了权重,我们后面样式想要覆盖,则需要更大的权重去处理,显然,代码就显得啰嗦了。
其实我们有很好的兼容区分策略,那就是充分利用浏览器对CSS属性本身的支持情况来实现浏览器的兼容区分,而不是传统的通过选择器或者一些查询语句。
就拿我们这里的盒阴影和边框例子举例,如果我来实现,则会是这样的:
.box { box-shadow: 0 1px 3px rgba(0,0,0,.25); border: 1px solid #d0d0d5; border: 0 rgba(0,0,0,.2);}
想要让IE9+浏览器没有边框其实很简单,只要使用一个只有IE9+认识的同时没有边框的书写形式就可以了。虽然border
所有浏览器都识别,但是rgba
色值确实IE9+浏览器才支持,于是,我们就可以巧妙利用IE8-浏览器不识别rgba
色值这一特性,实现我们的向下兼容处理。
由于IE8浏览器不认识rgba
颜色表示,因此,在IE8眼中,下面这种写法就是不合法的,就会被忽略:
border: 0 rgba(0,0,0,.2);
这种处理技巧就是本文所要说的,利用浏览器本身的不兼容实现我们的向下兼容效果。
里面的例子,理论上,直接使用rgba(0,0,0,0)
也是可以实现我们的效果的,少了1个字符,本来挺好。但是,如果你在Sass中写出border: 0 rgba(0,0,0,0);
,则会被Sass自以为是地编译成border: 0 transparent
,我靠,这个可就差了十万八千里了,虽然看表现rgba(0,0,0,0)
和transparent
是一个东西,都是透明,但是,对于border
属性而言,rgba(0,0,0,0)
IE9+浏览器才能识别,transparent
从IE7浏览器就开始识别了。于是乎,IE7,IE8浏览器下,本要出现的边框就这样直接被干掉了,妥妥的bug啊!为了规避这个让人无语的问题,这才使用了rgba(0,0,0,.2)
。
上面这个例子有demo,您可以狠狠地点击这里:CSS 盒阴影与边框向下兼容demo
利用类似属性值兼容性实现向下兼容的例子还有很多。
所有数值相关的兼容试试CSS3 calc()
比方说,上面IE9+去边框的例子,还可以试试这样:
.box { box-shadow: 0 1px 3px rgba(0,0,0,.25); border: 1px solid #d0d0d5; border: calc(0px + 0px) #000;}
因为CSS3 calc()
计算IE9+浏览器才开始支持。
背景图可是试试background多背景
这种背景图兼容处理其实非常常见,尤其你是一个喜欢SVG的小伙伴。我们可以使用SVG图形作为背景,这样retina显示屏下效果就蹭蹭蹭的好,但是,SVG有个问题,就是IE8浏览器不支持,怎么办?IE8浏览器就使用传统的图片,并且只需要1倍图就可以,对只需要1倍图,因为,我相信,这个世界是不存在哪个用户的设备是retina屏幕,但还使用IE8浏览器上网的。
下面就有个IE8浏览器向下兼容使用图片的处理问题了,大家都是背景图片,该怎么处理呢?好苦恼~~
哈哈,不要苦恼,background
属性虽然都支持,但是,background
的属性值和一些语法并不是所有浏览器都支持的哦,比方说多背景就是IE9浏览器才开始支持的,于是乎,我们可以这么处理:
.box { background: url(test.png); /* IE8 */background: url(test.svg), none; /* IE9+ */}
基本上,以上3个属性值兼容处理就能满足大部分现代浏览器和普通浏览器的区分了。但是,上面这几个例子都是区分IE9和其他低级浏览器的,有时候,我们希望区分IE10+和其他浏览器,该怎么办呢?要知道,IE10+的选择器hack非常难搞,但是,我们却有一些属性值hack,说不定会喜出望外的好用。
区分IE10+浏览器的属性hack技巧
通过一个经典的案例说明下,大家都知道IE10+开始支持了CSS3 animation
动画,于是乎,我们网页中常见的loading效果,就可以借助CSS3 animation
来实现,用一个静态的png图片,使用CSS3不停地旋转,效果即达成,且效果更细腻,体积超小,而且没有白色的锯齿,可谓上上之选。
下图为传统git图和png旋转图的尺寸对比:
可以看到大小完全不是一个量级的。
CSS3 animation
效果虽好,但是,最大的问题在于IE9及其以下浏览器不支持。本着面向未来,尽可能让用户感受最佳体验的原则,我们会想办法采取向下兼容的实现策略,就是支持CSS3动画的浏览器CSS3实现loading效果,浏览器要是不支持,则还使用gif,于是乎,技术实现的难度变成了如何区分IE9和IE10浏览器。
要区分IE9和IE8那方法很多,因为从CSS2到CSS3是巨变,但是从IE9到IE10那是微变,所以难度不小。CSS这么语言有趣就在于,你只要足够机灵,你总可以挖掘出一些小而美的处理技巧。
哪些CSS属性IE10支持,IE9不支持了,除了transition
和animation
,那就是gradient
背景渐变了,于是乎,我们就可以借助多背景,巧妙实现我们的兼容效果,核心CSS代码如下:
.box { background: url(loading_blue.gif) no-repeat center; background: url(loading_blue.png) no-repeat center, linear-gradient(to top, transparent, transparent); animation: spin 1s linear infinite;}
虽然IE9支持多背景,但是由于不认识渐变linear-gradient
语法,所以,下面那行background:...
CSS代码IE9不认识,于是,IE9就是要了上面的loading_blue.gif
,从而轻松实现CSS3 animation
下的loading效果的向下兼容效果。
您可以狠狠地点击这里:CSS png animation旋转向下兼容demo
Chrome浏览器下截图:
需要注意的是,下面的background
只能是background
,虽然理论上使用background-image
也是可以的,但是在IE7, IE8浏览器下面,background-image
如果是个不认识的东西,他们不会认为这行CSS无效,而是认为你这个背景图有问题,于是会导致IE7,IE8浏览器下连gif loading图片都实现不出来。
如何巧妙隐藏IE9及其以下浏览器版本中的元素
最近遇到一个项目,设计师设计的一些图形效果非常适合用CSS3绘制,其中有斜纹边框效果,这就导致只能兼容到IE10,IE9及其以下浏览器还是图片。
这个例子的HTML要比上面的loading案例要复杂,由于图形负责,因此,会有很多的HTML内容出现,而对于IE9,这些都是不需要的,因为背景图只需要一层标签即可。所以,这里出现了2处需要兼容处理的地方,其一,IE10+没有背景图;其二,IE9-里面的子元素要全部没效果,比方说隐藏。
第一个兼容处理好办,跟上面的loading处理类似:
.box { background: url(shape.png); background: linear-gradient(to top, transparent, transparent), none;}
关键里面的元素隐藏怎么办?有什么隐藏属性IE10认识,IE9不认识的?不好意思,没有,要么都认识,要么都不认识。难道没有什么处理方法了吗?有!
我们平时写CSS3属性的时候,习惯性会加私有前缀,虽然现在很多属性都不需要了,比方说:
.box { -webkit-animation: spin 1s linear infinite; animation: spin 1s linear infinite;}
这种私有前缀写法,本质上就是本文的利用浏览器的兼容性的向下兼容策略。所以,如果浏览器之间的属性支持有私有前缀之分,也是可以利用属性兼容性实现向下兼容效果的。
IE9和IE10之间需要私有前缀区分的CSS属性其实为数不多,其中之一就是transform
属性:
也就是IE9浏览器下,如果transform
不加私有前缀是不认识的。好了,我们有思路了,我们可以利用transform
来实现我们的隐藏效果。
核心CSS如下:
.box > div { position: relative; left: -999px; /* 所以浏览器偏移屏幕之外 */transform: translateX(999px); /* IE10+位置修正 */}
理论上,上面代码就可以满足我们的需求了。但是,注意的是,transform
需要私有前缀的浏览器是原生的IE9浏览器,用户使用的时候肯定都是使用原生版本的,如果从用户角度考虑,我们工作到此为止。但是,我们的测试同事很可能就是使用IE11等浏览器的向下兼容模式看的,要知道,IE11、IE9的transform
不需要-ms-
私有前缀也能识别,很可能你这里的实现就会被报bug.
所以,安全起见,我们需要对上面的CSS做进一步的处理,如下:
.box > div { position: relative; left: -999px; /* 所以浏览器偏移屏幕之外 */transform: translate3d(999px,0,0); /* IE10+位置修正 */}
嘿嘿,双保险,就算非原生IE9的transform
不需要-ms-
私有前缀,3d transform
那肯定是不认识的,于是乎,一个完美的区分IE10和IE9隐藏的向下兼容方案就实现了。
到此,关于"CSS怎么实现向下兼容"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!