漫谈@supports与CSS3条件规则

         好吧,好久没有聊CSS3了,今天我们来讲讲CSS3的最新特性。

         在Chrome最新的动态里,添加了对CSS.supports()方法的支持,而许多关注浏览器发展的朋友也可能已经了解到Firefox和Opera开始支持@supports规则。CSS.supports()和@supports看起来非常相似,它们之间有什么关联,它们的前世今生究竟是怎么一回事呢?

         为了应付浏览器分裂的CSS3支持情况、支持渐进增强式设计,我们之前经常采用Modernizr这个库来判断浏览器对于HTML5、CSS3的支持情况,以便有针对性的设计网站界面和功能。

         也许很快我们不再需要Modernizr,因为浏览器本身将会告诉我们这些信息。

         @supports的源起

         @supports其实来源于W3C的这份工作草案:《CSS Conditional Rules Module Level 3》,即CSS的条件规则模块:允许我们在不同条件下来定义CSS样式。众所周知,CSS2.1支持@media条件规则,可以根据不同的媒介来加载不同的样式表,这个功能虽然出发点很好,但是使用起来并不方便,因为开发者需要写多个样式表来对应不同的媒介,非常麻烦。这份新的规范扩展了@media规则,允许在一个CSS样式文件里根据不同的媒介来定义样式。同时此规范增加了另外一个群众呼声很高的条件规则,即@supports。在浏览器CSS新特性越来越常见、更新越来越迅速,网站功能越来越前卫的今天,它允许我们可以根据浏览器对CSS特性的支持情况来定义不同的样式。这对我们来说非常重要。

         W3C网站上的官方代码示例如下:

@supports ( display: flexbox ) {
  body, #navigation, #content { display: flexb
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值