• 豌豆资源网
  • 开引网企业服务
  • 服务外包网
  • css定义变量_css原生变量的使用和兼容 附带还有更高性能,文件更高压缩率的好处

    在开发中,css样式有一些属性往往需要重复使用,为了避免代码冗余,降低维护成本。我们需要使用CSS预编译工具【Sass/Less/Stylus】,随着这些工具的流行,CSS变量也开始规范制定,目前很多浏览器都已经支持了,css变量的兼容性:

     

    变量的定义:

    CSS中原生的变量定义语法是:--*,变量使用语法是:var(--*),其中*表示我们的变量名称。

    关于命名这个东西,各种语言都有些显示,例如CSS选择器不能是数字开头,JS中的变量是不能直接数值的,但是,在CSS变量中,这些限制通通没有。 但不能包含$,[,^,(,%等字符,普通字符局限在只要是“数字[0-9]”“字母[a-zA-Z]”“下划线_”和“短横线-”这些组合,但是可以是中文,日文或者韩文。

    无论是变量的定义和使用只能在声明块{}里面。

    51220网站目录 https://www.51220.cn

    变量的使用:

    1、使用:root 作用域来定义全局变量:(在媒体查询下也可以使用该作用域)

    :root {   
      --text-color: red;
    }  
    p {   
      color: var( --text-color );   /*使用*/
    }
    a:hover{
        color:var( --text-color );   /*在伪类中使用*/
    }

    2、如果只需要在特定的元素下使用变量,采用局部定义:

    #myid{
       --text-color: red;//*只能在id为myid的元素下使用,其他地方使用会失效*/
    }

    3、可以结合CSS3 calc()一起计算:

    p{
      --size: 20;   
      font-size: calc(var(--size) * 1px);//20px
    }

    4、css变量可以组合使用,在CSS变量定义的时候可以直接引入其他变量给自己使用,例如:

    p {
      --color: red;   
      --text-color: var(--color);//值为red
    }

     

    css变量的注意点:

    1、当存在多个同样名称的变量时候,变量的覆盖规则由CSS选择器的权重决定的,但并无!important这种用法。

    2、CSS属性名是不可以使用变量的。例如下面写法是错误的:

    body {
        --bc: background-color;    
        var(--bc): #369;
    }

    3、如果我们使用的变量没有定义(注意,仅限于没有定义),则使用后面的值作为元素的属性值,例如:

    .box {
      --1: #369;
    }
    body {
      background-color: var(--1, #cd0000);/*则此时的背景色是#cd0000*/
    }

    4、css变量是存在缺省值,只要定义正确,里面的值不对,结果以缺省值显示:如:

    body {
      --color: 20px;
      background-color: #369;
      background-color: var(--color, #cd0000);/*背景色为:transparent*/
    }

    5、css变量默认尾部是有空格的。例如:

    p{
      --size: 20;   
      font-size: var(--size)px;//等同于font-size:20 px;这里将使用元素默认的大小。这里可以结合上面例子calc()使用。
    }

     

    posted @ 2020-06-11 14:47  前端一点红  阅读(1710)  评论(0编辑  收藏  举报
  • 乐游资源网
  • 热爱资源网
  • 灵活用工代发薪平台
  • 企服知识
  • 355软件知识