css 是一些非常简单得语句的组合,既然简单的语句,就不可避免的有很多重复的,冗余的东西,而且没有传统
编程语言变量,控制语句等高级特性,所以造成了css 编写低效,往往需要查找替换,大量复制来修改或者编写。Sass 是用
弥补这些缺陷的,使开发更加的方便快捷,更加方便管理。
  1.Sass和SCSS的区别。
    文件扩展名不同,Sass 是以“.sass”后缀为扩展名,而 SCSS 是以“.scss”后缀为扩展名
    语法书写方式不同,Sass 是以严格的缩进式语法规则来书写,不带大括号({})和分号(;),而
  SCSS 的语法书写和我们的 CSS 语法书写方式非常类似。
    例如:Sass语法
      $font-stack: Helvetica, sans-serif //定义变量
      $primary-color: #333 //定义变量

      body
        font: 100% $font-stack
        color: $primary-color
    例如:SCSS语法
        $font-stack: Helvetica, sans-serif;
        $primary-color: #333;
    body {
      font: 100% $font-stack;
      color: $primary-color;
    }
   编译出来的 CSS
    body {
      font: 100% Helvetica, sans-serif;
      color: #333;
    }

在使用的页面时依然引用.css文件。
Sass中编译出来的样式风格可以按不同的样式风格显示。
  1.嵌套输出方式nested
    例如: nav {
          ul {
            margin: 0;
            padding: 0;
            list-style: none;
          }
          li { display: inline-block; }
          a {
            display: block;
            padding: 6px 12px;
            text-decoration: none;
           }
        }
    编译出来的风格:nav ul {
              margin: 0;
              padding: 0;
              list-style: none; }
            nav li {
              display: inline-block; }
            nav a {
              display: block;
              padding: 6px 12px;
              text-decoration: none; }
    2.展开输出方式expanded
        例如: nav {
              ul {
                margin: 0;
                padding: 0;
                list-style: none;
                }
          li { display: inline-block; }
          a {
            display: block;
            padding: 6px 12px;
            text-decoration: none;
            }
          }
      编译出来的风格:
        nav ul {
            margin: 0;
            padding: 0;
            list-style: none;
          }
        nav li {
          display: inline-block;
        }
        nav a {
          display: block;
          padding: 6px 12px;
          text-decoration: none;
        }
    3.紧凑输出方式 compact
      例如: nav {
            ul {
                margin: 0;
                padding: 0;
                list-style: none;
          }
        li { display: inline-block; }
        a {
          display: block;
          padding: 6px 12px;
          text-decoration: none;
          }
        }
    编译出来的风格:
      nav ul { margin: 0; padding: 0; list-style: none; }
      nav li { display: inline-block; }
      nav a { display: block; padding: 6px 12px; text-decoration: none; }
  4.压缩输出方式compressed
    例如: nav {
          ul {
            margin: 0;
            padding: 0;
            list-style: none;
            }
          li { display: inline-block; }
          a {
            display: block;
            padding: 6px 12px;
            text-decoration: none;
            }
        }
  编译出来的风格:
      nav ul{margin:0;padding:0;list-style:none}nav li{display:inline-block}nav a{display:block;padding:6px 12px;
          text-decoration:none}
  声明变量用“$”开头,
      $width:300px;
      "$":变量声明符
      width: 变量名称
      300px 变量值
  全局变量与局部变量
    在选择器、函数、混合宏...的外面定义的变量为全局变量
      例如:
        .block {
            color: $color;//调用全局变量
          }
        em {
            $color: red;//定义局部变量
        a {
            color: $color;//调用局部变量
          }
        }
      span {
        color: $color;//调用全局变量
      }
    编译后:
      //CSS
        .block {
            color: orange;
          }
        em a {
          color: red;
          }
       span {
        color: orange;
        }

      $color 就是一个全局变量,而定义在元素内部的变量,比如 $color:red; 是一个局部变量。
      什么时候声明变量?
          1.该值至少重复出现了两次;
          2.该值至少可能会被更新一次;
          3.该值所有的表现都与变量有关(非巧合)。
      Sass 的嵌套分为三种:
        选择器嵌套
        属性嵌套
        伪类嵌套
      例如:在css 会这样写
        nav a {
            color:red;
          }
      header nav a {
          color:green;
      }
    在sass中
    nav {
      a {
        color: red;
       header & {
      color:green;
      }
  嵌套-属性嵌套
  Sass中提供属性嵌套,css有一些属性前缀相同。
  例如用到的样式:
  .box{
    border-top:1px solid red;
    border-bottom:1px solid green;
  }
  在Sass中我们可以这样写:
  .box {
    border: {
    top: 1px solid red;
    bottom: 1px solid green;
    }
  }

Sass 基础(一)的更多相关文章

  1. [转]前端利器:SASS基础与Compass入门

    [转]前端利器:SASS基础与Compass入门 SASS是Syntactically Awesome Stylesheete Sass的缩写,它是css的一个开发工具,提供了很多便利和简单的语法,让 ...

  2. Sass基础——Rem与Px的转换

    rem是CSS3中新增加的一个单位值,他和em单位一样,都是一个相对单位.不同的是em是相对于元素的父元素的font-size进行计算:rem是相对于根元素html的font-size进行计算.这样一 ...

  3. sass基础编写流程

    这是之前整理在word上的基础流程 sass是Ruby语言开发的一个用于动态编程css文件的框架 所以sass的运行依赖Ruby环境 所以要先安装Ruby 参见详细教程(安装参照慕课网有详细的教程) ...

  4. 前端利器:SASS基础与Compass入门

    SASS是Syntactically Awesome Stylesheete Sass的缩写,它是css的一个开发工具,提供了很多便利和简单的语法,让css看起来更像是一门语言,这种特性也被称为“cs ...

  5. Sass基础语法

    Sass是CSS3语言的扩展,在CSS的基础之上添加了新特性和语法,能省事地写出更好的样式表.Sass引擎是基于Ruby的. 导入Sass文件: @import "colors" ...

  6. sass基础—具体编译步骤及对应命令:详细

    /*基础语法*/h1{ color: red;} /*变量定义*/ $color: red; /*嵌套*/body{ header{ } footer{ }} /*mixin函数*/@mixin al ...

  7. Sass 基础教程

    0. Sass 文件后缀名 sass 有两种后缀名文件:一种后缀名为 sass,不使用大括号和分号:另一种就是我们这里使用的 scss 文件,这种和我们平时写的 css 文件格式差不多,使用大括号和分 ...

  8. Sass 基础(七)

    Sass Maps 的函数-map-remove($map,$key),keywords($args) map-remove($map,$key) map-remove($map,$key)函数是用来 ...

  9. sass基础用法

    嵌套: 1.选择器嵌套: 2.属性嵌套; .box {     border-top: 1px solid red;     border-bottom: 1px solid green; } .bo ...

  10. sass笔记-3|Sass基础语法之样式复用和保持简洁

    上一篇详述了Sass如何嵌套.导入和注释这3个基本方式来保持条理性和可读性,这一篇更进一步地阐述sass保持样式复用和简洁的方式--混合器和选择器继承--这两种方式都能复用样式,使用它们也不难,但一定 ...

随机推荐

  1. ArrayList  集合

    ArrayList       集合:很多数据的一个集合       数组:长度不可变.类型单一 集合的好处:长度可以任意改变  类型随便 集合长度都的问题   很多数据的集合数组类型不可变 长度单一 ...

  2. artDialog组件应用学习(四)

    一.在对话框自定义操作按钮 预览: html调用代码: var btnArray = [ { value: '同意', callback: function () { this.content('你同 ...

  3. 01.里氏准换与using关键字

    using关键字有什么用?什么是IDisposable? using可以声明namespace的引入,还可以实现非托管资源的释放,实现了IDisposiable的类在using中创建,using结束后 ...

  4. mac解决系统设置安全与隐私没有允许所有来源

    解决系统设置安全与隐私没有允许所有来源:sudo spctl --master-disable

  5. Android使用Gradle命令动态传参完成打包,不需要修改代码

    不得不说,Gradle很强大,有人会问Gradle是什么?这里也不细讲,在我认为他就是一个构建神器.Gradle 提供了: 一个像 Ant 一样的非常灵活的通用构建工具 一种可切换的, 像 Maven ...

  6. SQL获取本周,上周,本月,上月的开始时间和结束时间

    ),),--本周 ),),--上周 ),),--本月 ),),--上月 ),),--近半年 ),)--近一年 ), ,, ),)--本周开始时间 ), ,, ),)--本周结束时间 ),,, ),)- ...

  7. 环境变量PATH超长问题[转]

    症状回放: 最近安装一个Delphi的控件,结果,在安装之后启动Delphi时出现了找不到相关文件的错误.一开始以为是Delphi内的Library路径没有添加,查看,一切正常.再次启动Delphi, ...

  8. vs2015编译纯ASM文件

    x86: 1. 创建一个 C++ 的空项目. 2.解决方案管理器 - 目标项目名 - 右键 - 生成依赖项 - 生成自定义 (VS2015, 如果使用VS2010 你右键就直接能看到生成自定义) 3. ...

  9. SONA Topology

    N多年以前就有有人设计传了一种类似“房子”状结构的拓扑图,在Cisco的文档中可以查到这种叫SONA.这是个非常神奇的设计,适合用于中小型网络,之所以这么讲,是因为在这个结构下,但凡任何一台接入层或者 ...

  10. 从数据流角度管窥 Moya 的实现(一):构建请求

    相信大家都封装过网络层. 虽然系统提供的网络库以及一些著名的第三方网络库(AFNetworking, Alamofire)已经能满足各种 HTTP/HTTPS的网络请求,但直接在代码里用起来,终归是比 ...