compass 是sass的一个工具库
  compass在sass 的基础上封装了一系列有用的模块,用来补充和丰富sass的工能,

  安装:
    compass是用 ruby语言开发的,所以安装它之前必须安装ruby。
  命令:

    gem install compass
  项目初始化:
    要创建一个你的Compass 项目,如果项目的名字叫 myproject
      compass create myproject
    会在当前的目录下生成这个目录,里面有config.rb文件,还有两个子目录sass 和 stylesheets 前者存放sass 源文件,后者放编译后的
css文件。

  编译:
    我在开发的时候写出来的是文件后缀名为scss的文件。只有编译成css文件,才能用到网站上。
      compass 的编译命令为
        compass compile
    该命令在项目根目录下运行,将会sass 子目录中的scss 文件编译成css文件,保存在stylesheets子目录中。
      默认编译出来的css 文件带有大量的注释,生产环境需要压缩后的css文件
        compass compile --output-style compressed
    如果重新编译未修改过的文件
        compass compile --force
    除了使用命令参数,还可以在配置文件config.rb 中指定编译模式。

      output_style = :expanded
        :expanded 表示编译后保留原格式, 其他值还包括: nested,
        :compact和compressed 进入生产阶段后,就要改为:compressed模式。
          output_style = :compressed
    也可以通过指定environment的值(:production或者:development),智能判断编译模式。

      environment = :development
        output_style = (environment == :production) ? :compressed : :expanded

    在命令行模式下,除了一次性编译命令,compass还有自动编译命令

      compass watch
        只要scss文件发生变化,就会被自动编译成css文件。

compass 的模块

    compass采用模块结构,不同模块提供不同的功能,内置5个模块。
    reset css3 layout typography unilities

  reset模块

    在编写自己的样式之前,有必要重置浏览器的默认样式。
      写法是:
        @import "compass/reset"
    上面的@import命令,用来指定加载模块,这里就是加载reset模块。编译后,会生成相应的css reset代码。

  CSS3模块
    该模块提供24 中css3命令。如:
      圆角(border-radius) 的写法,
        @import "compass/css3";
            .rounded {
                @include border-radius(5px);
            }
    上面的@include命令,表示调用某个mixin(类似于C语言的宏),5px是参数,这里用来指定圆角的半径。

    编译后的代码为:
      .rounded {
        -moz-border-radius: 5px;
        -webkit-border-radius: 5px;
        -o-border-radius: 5px;
        -ms-border-radius: 5px;
        -khtml-border-radius: 5px;
        border-radius: 5px;
      }

    如果只需要左上角为圆角,写法为
    @include border-corner-radius(top, left, 5px);

  layout模块
    该模块提供布局功能,
    比如,指定页面的footer部分出现在浏览器的最低端。
      @import "compass/layout";
        #footer {
          @include sticky-footer(54px);
        }
    指定子元素占满父元素的空间:

      @import "compass/layout";
        #stretch-full {
          @include stretch;
        }
  typography模块
    该模块提供板式功能
      比如,指定链接颜色的mixin为:
        link-colors($normal, $hover, $active, $visited, $focus);
      使用时写成:
        @import "compass/typography";
          a {
            @include link-colors(#00c, #0cc, #c0c, #ccc, #cc0);
        }

  utilities模块

    该模块提供某些不属于其他模块的功能。
    比如,清除浮动:

      import "compass/utilities/";
        .clearfix {
          @include clearfix;
       }
    比如表格:
      @import "compass/utilities";
        table {
          @include table-scaffolding;
        }

    编译后
       table th {
        text-align: center;
        font-weight: bold;
        }
      table td,
      table th {
        padding: 2px;
      }
      table td.numeric,
      table th.numeric {
        text-align: right;
      }

    Helper函数
      除了模块外,compass还提供了一系列函数。
      有一些有用的函数,image-width() 和image-height() 返回图片的宽和高
      再比如,inline-image()可以将图片转为data协议的数据。

        @import "compass";
        .icon { background-image: inline-image("icon.png");}

        编译后得到
          .icon { background-image: url('data:image/png;base64,iBROR...QmCC');}
            函数与mixin的主要区别是,不需要使用@include命令,可以直接调用。

Sass与Compass——回顾的更多相关文章

  1. 分享15款很实用的 Sass 和 Compass 工具

    Sass 是 CSS 的扩展,增加了嵌套规则,变量,混入功能等很多更多.它简化了组织和维护 CSS 代码的成本.Compass 是一个开源的 CSS 框架,使得使用 CSS3 和流行的设计模式比以往任 ...

  2. Sass和compass 安装 和配合grunt实时显示 [Sass和compass学习笔记]

    demo 下载http://vdisk.weibo.com/s/DOlfkrAWjkF/1401192855 为什么要学习Sass和compass ?提高站独立和代码产品化的绝密武器,尤其是程序化cs ...

  3. 揭开Sass和Compass的神秘面纱

    揭开Sass和Compass的神秘面纱 可能之前你像我一样,对Sass和Compass毫无所知,好一点儿的可能知道它们是用来作为CSS预处理的.那么,今天请跟我一起学习下Sass和Compass的一些 ...

  4. Sass学习之路:Sass、Compass安装与命令行

    导言 CSS不是一门真正意义上的编程语言,很多编程语言理所当然的特性(比如变量),都不被支持.同时再开发模块化的web项目的时候,也要避免相互干扰.为了弥补CSS的这些不足,就产生了CSS预处理器,S ...

  5. Sass和Compass制作雪碧图

    1.安装好了sass与compass之后设置一个配置文件 2.新增一个雪碧图文件夹用来存放将要合并的图片例如color文件夹 3.@import命令引用 .Compass看到@import指令的参数为 ...

  6. 【Sass初级】开始使用Sass和Compass

    转自:http://www.w3cplus.com/preprocessor/beginner/getting-started-with-sass-and-compass.html 如果你的朋友.同事 ...

  7. Sass和Compass设计师指南

    注:配合查看:Sass 为什么使用Sass和Compass? 1.减少重复工作,加快开发进度 2.使用变量,便于记忆,变量使用$符号开头 3.自动转换RGBA颜色值 .color { color: $ ...

  8. SASS、COMPASS 安装指南

    如果你还不知道 SASS 和 COMPASS 是什么,可以参看http://sass-lang.com 和http://compass-style.org,近期可能会更新一篇介绍性的入门教程,但 是本 ...

  9. rub、sass和compass的安装

    长话短说,直接进入正题. [ruby安装] ruby下载网址:http://rubyinstaller.org/downloads/ 选择适合自己电脑的版本: 下载完成后直接双击安装,记得勾选加入环境 ...

随机推荐

  1. (中等) HDU 4979 A simple math problem. , DLX+重复覆盖+打表。

    Description Dragon loves lottery, he will try his luck every week. One day, the lottery company brin ...

  2. List的输出方法

    1.for (int i = 0; i < list.size(); i++) {    System.out.println(list.get(i));} 2.List list = new  ...

  3. MySql存储过程—7、游标(Cursor)

    |字号 订阅 1.游标的作用及属性 游标的作用就是用于对查询数据库所返回的记录进行遍历,以便进行相应的操作:游标有下面这些属性: a.游标是只读的,也就是不能更新它: b.游标是不能滚动的,也就是只能 ...

  4. iOS学习笔记(十三)——获取手机信息(UIDevice、NSBundle、NSLocale)

    iOS的APP的应用开发的过程中,有时为了bug跟踪或者获取用反馈的需要自动收集用户设备.系统信息.应用信息等等,这些信息方便开发者诊断问题,当然这些信息是用户的非隐私信息,是通过开发api可以获取到 ...

  5. ASIHTTPRequest异步请求

    我们运行程序,如果网速很慢,查询的时候会一直黑屏,直到请求结束画面才出现,这样用户体验很不好.因此同步请求一般只是在某个子线 程中使用,而不在主线程中使用.异步请求的用户体验要比同步请求好,因此一般情 ...

  6. Test 17

    BZ OI 队测 T1: 题目大意: 喵星系有n个星球,标号为1到n,星球以及星球间的航线形成一棵树. 所有星球间的双向航线的长度都为1.小昕要在若干个星球建矿石仓库,设立每个仓库的费用为K.对于未设 ...

  7. css--position和float

    1.元素设置position:relative或者position:absolute后,才能激活left,top,right,bottom和z-index属性,默认情况下这些属性并未激活,设置了也会无 ...

  8. java爬虫技术

    原博:http://983836259.blog.51cto.com/7311475/1730243 开源爬虫分类: 1.分布式爬虫:Nutch 2.JAVA单机爬虫:Crawler4j.WebMag ...

  9. App外包开发周期一般多长?

    很多人问我,开发一个app要用多长时间.事实上开发一款app没有固定周期的,得因产品而论,你软件的功能需求决定了app外包开发的周期.但是除了app本身以外,人为因素往往对开发周期也有一定的影响.例如 ...

  10. --@angularJS--指令与控制器之间较复杂的交互demo2

    1.index.html: <!DOCTYPE HTML><html ng-app="app"><head>    <title>c ...