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

如何在CSS中使用@supports

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

如何在CSS中使用@supports

今天就跟大家聊聊有关如何在CSS中使用@supports,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

基于浏览器的特性检测大家应该已经很熟悉了,特别是modernizr.js推出来之后。其实w3c也出了规范,可以基于css来做一些特性检测,也就是@supports,这个特性已经有两年多了,之前浏览器支持度不够,现在webkit nightly也开始支持了,也就是说safari 9会支持到,这样的话,Blink+webKit+gecko都支持了,只剩下IE浏览器不支持了,嗯,这样更方便对IE差异化处理了。

但是@supports并不能完全替代JS的特性检测方法,它只支持对CSS属性的检测,其它HTML5 api以及webP等技术的检测还是需要JS来完成。
用法:

@supports就像media query一样简单:

CSS Code复制内容到剪贴板

  1. @supports(prop:value) {  }  

@supports也允许你用各种复杂的组合来进行特性检测。
基本用法:

CSS Code复制内容到剪贴板

  1. @supports (display: flex) { div { display: flex; } }  

你可以用这种方法来检测各种基本的CSS属性。
not关键词

就像这样:

CSS Code复制内容到剪贴板

  1. @supports not (display: flex) { div { float: left; }  }  

个人感觉有些鸡肋了,支持@supports的浏览器会不支持各种CSS属性么?不过万事没有绝对,这种情况以后还是可能会有。嗯,私有前缀的话可以试试。
多条件检测

CSS Code复制内容到剪贴板

  1. @supports (display: -webkit-flex) or (display: -moz-flex) or (display: flex) {  }   

  2.   

  3.  @supports (display: flex) and (-webkit-appearance: caret) {  }  

你也可以将or和and语句放在一起混用。

CSS Code复制内容到剪贴板

  1. @supports ((display: -webkit-flex) or (display: -moz-flex) or (display: flex)) and (-webkit-appearance: caret) {  }  

或者更复杂的:

CSS Code复制内容到剪贴板

  1. @supports ( not ((text-align-last:justify) or (-moz-text-align-last:justify) ){ …  }  

JS方法

同时也可以用javascript来做类似的检测,方法也很简单:

CSS Code复制内容到剪贴板

  1. boolValue = CSS.supports(propertyName, value); boolValue = CSS.supports(supportCondition);  

两种方法都可以,会返回一个bool值。比如:

CSS Code复制内容到剪贴板

  1. result = CSS.supports("text-decoration-style", "blink");     

  2. result = CSS.supports("display", "flex");     

  3. result = CSS.supports("( transform-origin: 5% 5% )");     

  4. result = CSS.supports("( transform-style: preserve ) or ( -moz-transform-style: preserve ) or ( -o-transform-style: preserve ) or ( -webkit-transform-style: preserve )" );    

用途

最大的用途是做css特性判断的时候,不用再在js(或者传统的js方法)了,用过modernizr.js的同学可能会印象很深刻,modernizr会在html标签上加上各种各样的class来区分,其它js方法也是类似的实现思路。现在可以直接用@supports来区分或者做浏览器差异化了。
浏览器支持

    chrome 28+
    opera 12.1+
    firefox22+
    safari 9+

看完上述内容,你们对如何在CSS中使用@supports有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网行业资讯频道,感谢大家的支持。

免责声明:

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

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

如何在CSS中使用@supports

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

下载Word文档

猜你喜欢

如何在CSS中使用@supports

今天就跟大家聊聊有关如何在CSS中使用@supports,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。基于浏览器的特性检测大家应该已经很熟悉了,特别是modernizr.js推出来之
2023-06-09

escape在css中如何使用

本篇内容主要讲解“escape在css中如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“escape在css中如何使用”吧!escape在css中的使用语法是“escapedStr = C
2023-07-05

fraction如何在css中使用

本篇文章给大家分享的是有关fraction如何在css中使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。css的选择器有哪些css的选择器可以分为三大类,即id选择器、cla
2023-06-14

如何在CSS中使用定位

今天就跟大家聊聊有关如何在CSS中使用定位,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。CSS中定位介绍position 属性在英文单词中表示 位置 的意思,在 CSS 中主要作用设
2023-06-08

如何在css中使用position属性

如何在css中使用position属性?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。position 属性值的含义:static元素框正常生成。块级元素生成一个
2023-06-08

如何在CSS中使用 var()变量

今天就跟大家聊聊有关如何在CSS中使用 var()变量,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。定义和使用CSS变量与任何其他CSS定义一样,变量遵循相同的范围和继承规则。使用它
2023-06-08

如何在css中使用content属性

如何在css中使用content属性?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。content属性一般用于::before、::after伪元素中,用于呈现伪元素的内容。平时
2023-06-08

如何在CSS中使用outline属性

这篇文章给大家介绍如何在CSS中使用outline属性,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。轮廓(outline)是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。轮廓(outline)属性指
2023-06-08

如何在css中使用border属性

今天就跟大家聊聊有关如何在css中使用border属性,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、CSS边框基础知识CSS 边框即CSS border是控制对象的边框边线宽度、
2023-06-08

如何在css中使用display:block;属性

本篇文章为大家展示了如何在css中使用display:block;属性,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。对所有的块元素都没有意义,块元素的dispaly属性默认值为block,没必要再显
2023-06-09

如何在css中使用transition属性

这篇文章给大家介绍如何在css中使用transition属性,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。css的三种引入方式1.行内样式,最直接最简单的一种,直接对HTML标签使用style=""。2.内嵌样式,就是
2023-06-08

如何在css中使用display:box 属性

本篇文章为大家展示了如何在css中使用display:box 属性,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、display:box;  在元素上设置该属性,可使其子代排列在同一水平上,类似d
2023-06-08

如何在css中如何定义使用变量

今天就跟大家聊聊有关如何在css中如何定义使用变量,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。CSS中原生的变量定义语法是:--*,变量使用语法是:var(--*) ; 其中*
2023-06-15

如何在CSS中使用Sprite雪碧图

本篇文章为大家展示了如何在CSS中使用Sprite雪碧图,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。雪碧图的使用场景静态图片,不随用户信息的变化而变化。小图片,容量比较小(2~3k)。图片加载量比
2023-06-08

如何在CSS中使用pointer-events属性

今天就跟大家聊聊有关如何在CSS中使用pointer-events属性,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在关闭弹层时,以fadeOut动画效果为例,我这里是利用opaci
2023-06-08

如何在css中使用line-height属性

这期内容当中小编将会给大家带来有关如何在css中使用line-height属性,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、line-height语法line-height属性的具体定义列表如下:语法
2023-06-08

如何在CSS中使用position:fixed和margin-top

这期内容当中小编将会给大家带来有关如何在CSS中使用position:fixed和margin-top,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。问题描述想用CSS实现顶部固定的效果:尝试margin-
2023-06-08

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录