美文网首页web端学习
css的预处理器

css的预处理器

作者: 晨曦诗雨 | 来源:发表于2018-11-21 10:24 被阅读20次

    一.什么是CSS的预处理器

    CSS预处理器定义了一种新的语言,基本的思想是用一种专门的编程语言,开发者只需要使用这种语言进行编码工作,减少枯燥无味的CSS代码的编写过程的同时,它能让你的CSS具备更加简洁、适应性更强、可读性更加、层级关系更加明显、更易于代码的维护等诸多好处

    二.CSS的预处理器有哪些

    CSS预处理器种类繁多,本次就以Sass、Less、Stylus进行比较。

    三.CSS的预处理的比较

    1.Scss

    在线编译器 https://www.sassmeister.com/

    Sass 是一款强化 CSS 的辅助工具,它在 CSS 语法的基础上增加了变量 (variables)、嵌套 (nested rules)、混合 (mixins)、导入 (inline imports) 等高级功能,这些拓展令 CSS 更加强大与优雅。使用 Sass 以及 Sass 的样式库(如 Compass)有助于更好地组织管理样式文件,以及更高效地开发项目。

    • 1.特色功能

    完全兼容 CSS3
    在 CSS 基础上增加变量、嵌套 (nesting)、混合 (mixins) 等功能
    通过函数进行颜色值与属性值的运算
    提供控制指令 (control directives)等高级功能
    自定义输出格式

    其实现在的Sass已经有了两套语法规则:一个依旧是用缩进作为分隔符来区分代码块的;另一套规则和CSS一样采用了大括号({})作为分隔符。后一种语法规则又名SCSS,在Sass3之后的版本都支持这种语法规则。

    注:Sass官网地址:http://sass-lang.com

    • 2.Less
      2009年开源的一个项目,受Sass的影响较大,但又使用CSS的语法,让大部分开发者和设计师更容易上手。LESS提供了多种方式能平滑的将写好的代码转化成标准的CSS代码,在很多流行的框架和工具中已经能经常看到LESS的身影了(例如Twitter的Bootstrap框架就使用了LESS)。

    根据维基百科上的介绍,其实LESS是Alexis Sellier受Sass的影响创建的一个开源项目。当时SASS采用了缩进作为分隔符来区分代码块,而不是CSS中广为使用的大括号({})。为了让CSS现有的用户使用起来更佳方便,Alexis开发了LESS并提供了类似CSS的书写功能。

    注:LESS的官网:http://lesscss.org

    • 3.Stylus
    中文文档 https://www.zhangxinxu.com/jq/stylus/

    Stylus,2010年产生,来自于Node.js社区,主要用来给Node项目进行CSS预处理支持,在此社区之内有一定支持者,在广泛的意义上人气还完全不如Sass和LESS。

    Stylus被称为是一种革命性的新语言,提供一个高效、动态、和使用表达方式来生成CSS,以供浏览器使用。Stylus同时支持缩进和CSS常规样式书写规则。

    注:Stylus官网:http://learnboost.github.com/stylus

    预处理器的安装可以参照此网 https://blog.csdn.net/ly2983068126/article/details/77737292

    四.语法

    在使用CSS预处理器之前最重要的是了解语法与大家对比分享。

    首先Sass和Less都是用的是标准的CSS语法,因此你可以很方便的把已完成的CSS代码转为预处理器识别的代码,Sass默认使用 .sass扩展名,而Less默认使用.Less扩展名Stylus的默认使用.styl扩展名

    语法:

    Scass

    Sass3.0版本开始使用的是标准的CSS语法,和SCSS可以说是一样的。这样Sass代码转换成CSS代码变得更容易。默认Sass使用“.scss”扩展名。Sass语法规则可以像CSS那样书写:

    /*style.sass新版语法规则*/
    h1{
      color:#936;
      background-color:#333;
    }
    

    正如你所看到的,在Sass样式中,这样的代码是在简单不过的了。

    重要的一点是,Sass也同时支持老的语法,老的语法和常规的CSS语法略有不同,他需要严格的语法,任何的缩进和字符的错误都会造成样式的编译错误。Sass可以省略大括号({})和分号(;),完全依靠严格的缩进和格式化代码,而且文件使用“.sass”扩展名,他的语法类似于:

    /*style.sass*/
    h1
      color:#936
      background-color: #333
    
    Less

    LESS是CSS的一种扩展形式,它并没有阉割CSS的功能,而是在现有的CSS语法上,添加了很多额外的功能。就语法规则而言,LESS和Sass一样,都是使用CSS的标准语法,只是LESS的源文件的扩展名是“.less”,其基本语法类似于:

    /*style.less*/
    h1 {
      color: #963;
      background-color: #333;
    }   
    
    Stylus

    Stylus的语法花样多一些,它的文件扩展名是“.styl”,Stylus也接受标准的CSS语法,但是他也像Sass老的语法规则,使用缩进控制,同时Stylus也接受不带大括号({})和分号的语法,如下所示:

    /*style.styl*/
    /*类似于CSS标准语法*/
    h1 {
      color: #963;
      background-color:#333;
    }
    
    /*省略大括号({})*/
    h1 
      color: #963;
      background-color: #333;
    /*省略大括号({})和分号(;)*/
    
    h1
      color:#963
      background-color:#333
    

    在Stylus样式中,你也可以在同一个样式文件中使用不同的语法规则,下面这样的写法也不会报错:

    /*style.styl*/
    h1 {
      color  #963
    }
    h2 
      font-size:1.2em   
    

    变量

    你可以在 CSS 预处理器中声明变量,并在整个样式单中使用,支持任何类型的变量,例如颜色、数值(不管是否包括单位)、文本。然后你可以任意引用该变量。
    Sass 的变量必须是 $ 开始,然后变量名和值使用冒号隔开,跟 CSS 的属性一致:

    $mainColor: #0982c1;
    $siteWidth: 1024px;
    $borderStyle: dotted;
     
    body {
      color: $mainColor;
      border: 1px $borderStyle $mainColor;
      max-width: $siteWidth;
    }
    

    而 Less 的变量名使用 @ 符号开始:

    @mainColor: #0982c1;
    @siteWidth: 1024px;
    @borderStyle: dotted;
     
    body {
      color: @mainColor;
      border: 1px @borderStyle @mainColor;
      max-width: @siteWidth;
    }
    

    Stylus 对变量名没有任何限定,你可以是 $ 开始,也可以是任意的字符,而且与变量值之间可以用冒号、空格隔开,需要注意的是 Stylus (0.22.4) 将会编译 @ 开始的变量,但其对应的值并不会赋予该变量,换句话说,在 Stylus 的变量名不要用 @ 开头。

    mainColor = #0982c1
    siteWidth = 1024px
    $borderStyle = dotted
     
    body
      color mainColor
      border 1px $borderStyle mainColor
      max-width siteWidth
    

    上面的三种不同的 CSS 预处理器的写法,最终都将产生相同的结果:

    body {
      color: #0982c1;
      border: 1px dotted #0982c1;
      max-width: 1024px;
    }
    

    你可以想象,加入你的 CSS 中使用了某个颜色的地方多达数十次,那么要修改颜色时你必须找到这数十次的地方并一一修改,而有了 CSS 预处理器,修改一个地方就够了!

    嵌套

    如果我们需要在CSS中相同的 parent 引用多个元素,这将是非常乏味的,你需要一遍又一遍地写 parent。例如:

    section {
      margin: 10px;
    }
    section nav {
      height: 25px;
    }
    section nav a {
      color: #0982C1;
    }
    section nav a:hover {
      text-decoration: underline;
    }
    

    而如果用 CSS 预处理器,就可以少些很多单词,而且父子节点关系一目了然。我们这里提到的三个 CSS 框架都是允许嵌套语法:

    section {
      margin: 10px;
    
      nav {
        height: 25px;
    
        a {
          color: #0982C1;
    
          &:hover {
            text-decoration: underline;
          }
        }
      }
    }
    

    最终生成的 CSS 结果是:

    section {
      margin: 10px;
    }
    section nav {
      height: 25px;
    }
    section nav a {
      color: #0982C1;
    }
    section nav a:hover {
      text-decoration: underline;
    }
    

    Mixins (混入)

    Mixins 有点像是函数或者是宏,当你某段 CSS 经常需要在多个元素中使用时,你可以为这些共用的 CSS 定义一个 Mixin,然后你只需要在需要引用这些 CSS 地方调用该 Mixin 即可。

    Sass 的混入语法:

    @mixin error($borderWidth: 2px) {
      border: $borderWidth solid #F00;
      color: #F00;
    }
    
    .generic-error {
      padding: 20px;
      margin: 4px;
      @ include error(); /* Applies styles from mixin error */
    }
    .login-error {
      left: 12px;
      position: absolute;
      top: 20px;
      @ include error(5px); /* Applies styles from mixin error with argument $borderWidth equal to 5px*/
    }
    

    Less CSS 的混入语法:

    .error(@borderWidth: 2px) {
      border: @borderWidth solid #F00;
      color: #F00;
    }
    
    .generic-error {
      padding: 20px;
      margin: 4px;
      .error(); /* Applies styles from mixin error */
    }
    .login-error {
      left: 12px;
      position: absolute;
      top: 20px;
      .error(5px); /* Applies styles from mixin error with argument @borderWidth equal to 5px */
    }
    

    Stylus 的混入语法:

    error(borderWidth= 2px) {
      border: borderWidth solid #F00;
      color: #F00;
    }
    
    .generic-error {
      padding: 20px;
      margin: 4px;
      error(); /* Applies styles from mixin error */
    }
    .login-error {
      left: 12px;
      position: absolute;
      top: 20px;
      error(5px); /* Applies styles from mixin error with argument borderWidth equal to 5px */
    }
    

    最终它们都将编译成如下的 CSS 样式:

    error {
      padding: 20px;
      margin: 4px;
      border: 2px solid #f00;
      color: #f00;
    }
    .login-error {
      left: 12px;
      position: absolute;
      top: 20px;
      border: 5px solid #f00;
      color: #f00;
    }
    
    继承

    当我们需要为多个元素定义相同样式的时候,我们可以考虑使用继承的做法。例如我们经常需要:

    p,
    ul,
    ol {
      /* styles here */
    }
    

    在 Sass 和 Stylus 我们可以这样写:

    .block {
      margin: 10px 5px;
      padding: 2px;
    }
    
    p {
      @extend .block; /* Inherit styles from '.block' */
      border: 1px solid #EEE;
    }
    ul, ol {
      @extend .block; /* Inherit styles from '.block' */
      color: #333;
      text-transform: uppercase;
    }
    

    在这里首先定义 .block 块,然后让 p 、ul 和 ol 元素继承 .block ,最终生成的 CSS 如下:

    .block, p, ul, ol {
      margin: 10px 5px;
      padding: 2px;
    }
    p {
      border: 1px solid #EEE;
    }
    ul, ol {
      color: #333;
      text-transform: uppercase;
    }
    

    在这方面 Less 表现的稍微弱一些,更像是混入写法:

    .block {
      margin: 10px 5px;
      padding: 2px;
    }
    
    p {
      .block; /* Inherit styles from '.block' */
      border: 1px solid #EEE;
    }
    ul, ol {
      .block; /* Inherit styles from '.block' */
      color: #333;
      text-transform: uppercase;
    }```
    
    
    生成的 CSS 如下:
    
    ```.block {
      margin: 10px 5px;
      padding: 2px;
    }
    p {
      margin: 10px 5px;
      padding: 2px;
      border: 1px solid #EEE;
    }
    ul,
    ol {
      margin: 10px 5px;
      padding: 2px;
      color: #333;
      text-transform: uppercase;
    }
    

    你所看到的上面的代码中,.block 的样式将会被插入到相应的你想要继承的选择器中,但需要注意的是优先级的问题。

    导入 (Import)

    很多 CSS 开发者对导入的做法都不太感冒,因为它需要多次的 HTTP 请求。但是在 CSS 预处理器中的导入操作则不同,它只是在语义上包含了不同的文件,但最终结果是一个单一的 CSS 文件,如果你是通过 @ import "file.css"; 导入 CSS 文件,那效果跟普通的 CSS 导入一样。注意:导入文件中定义的混入、变量等信息也将会被引入到主样式文件中,因此需要避免它们互相冲突。

    reset.css:

    body {
      background: #EEE;
    }
    

    main.xxx:

    @ import "file.{type}";
    
    p {
      background: #0982C1;
    }
    

    最终生成的 CSS:

    @ import "reset.css";
    body {
      background: #EEE;
    }
    p {
      background: #0982C1;
    }
    
    颜色函数

    CSS 预处理器一般都会内置一些颜色处理函数用来对颜色值进行处理,例如加亮、变暗、颜色梯度等。

    Sass:

    darken($color, 10%);  /* returns a color 10% darker than $color */
     saturate($color, 10%);   /* returns a color 10% more saturated than $color */
    desaturate($color, 10%); /* returns a color 10% less saturated than $color */
     grayscale($color);  /* returns grayscale of $color */
    complement($color); /* returns complement color of $color */
    invert($color);     /* returns inverted color of $color */
     mix($color1, $color2, 50%); /* mix $color1 with $color2 with a weight of 50% */
    

    上面只是简单列了 Sass 的一些基本颜色处理函数,完整的列表请看 Sass Documentation.

    下面是一个具体的例子:

    
    h1 {
      background: $color;
      border: 3px solid darken($color, 50%);
    }
    

    Less CSS:

    darken(@color, 10%);  /* returns a color 10% darker than @color */
    
    saturate(@color, 10%);   /* returns a color 10% more saturated than @color */
    desaturate(@color, 10%); /* returns a color 10% less saturated than @color */
    
    spin(@color, 10);  /* returns a color with a 10 degree larger in hue than @color */
    spin(@color, -10); /* returns a color with a 10 degree smaller hue than @color */
    
    mix(@color1, @color2); /* return a mix of @color1 and @color2 */
    

    LESS 完整的颜色函数列表请看 LESS Documentation.

    LESS 使用颜色函数的例子:

    
    h1 {
      background: @color;
      border: 3px solid darken(@color, 50%);
    }
    

    Stylus:

    darken(color, 10%);  /* returns a color 10% darker than 'color' */
    
    saturate(color, 10%);   /* returns a color 10% more saturated than 'color' */
    desaturate(color, 10%); /* returns a color 10% less saturated than 'color' */
    

    Stylus完整的颜色函数列表请阅读 Stylus Documentation.

    实例:

    
    h1
      background color
      border 3px solid darken(color, 50%)
    
    运算符

    你可以直接在 CSS 预处理器中进行样式的计算,例如:

      margin: (14px/2);
      top: 50px + 100px;
      right: 100px - 50px;
      left: 10 * 10;
    }
    

    一些跟具体浏览器相关的处理

    这是宣传使用预处理的原因之一,并且是一个很好的理由,这样可以节省的大量的时间和汗水。创建一个mixin来处理不同浏览器的CSS写法是很简单的,节省了大量的重复工作和痛苦的代码编辑。

    Sass

      -webkit-border-radius: $values;
         -moz-border-radius: $values;
              border-radius: $values;
    }
    
    div {
      @ include border-radius(10px);
    }
    

    Less CSS

      -webkit-border-radius: @values;
         -moz-border-radius: @values;
              border-radius: @values;
    }
    
    div {
      .border-radius(10px);
    }
    

    Stylus

      -webkit-border-radius: values;
         -moz-border-radius: values;
              border-radius: values;
    }
    
    div {
      border-radius(10px);
    }
    

    编译结果:

      -webkit-border-radius: 10px;
         -moz-border-radius: 10px;
              border-radius: 10px;
    }
    
    注释

    以上三种框架都支持形如 / / 的多行注释以及 // 的单行注释。

    相关文章

      网友评论

        本文标题:css的预处理器

        本文链接:https://www.haomeiwen.com/subject/dadqqqtx.html