SASS的使用

前端开发规范

每个一个前端都会包含库类、jQuery插件以及很多的各种各样目的的JS、CSS文件,有效管理不同的技术、不同文档集中起来运行良好确实需要一个很好的得工作流。因此,我们需要遵循开发模式、开发约定、文件组织良好,以保持所有的文档结构清晰、便于管理。
每一个项目的根目录下有以下目录:

  • CSS
    —存放css文件,basic.css、font.css、color.css...
  • JS
    —存放所有的js文件,可以包括几个子文件夹
  • views
    —视图,每个显示文件对应一个视图
  • images
    —存放所有的图片。

为了提高项目的开发效率和质量,我们使用各种工具来管理css或者js。例如:

  1. 使用sass来管理前端的css文件。
  2. 使用coffeescript来管理js文件。

SASS

SASS是最早、最成熟的CSS预处理,它可以通过变量、嵌套、函数、继承等使CSS变得更强大,更优雅,而且完全兼容CSS的语法。
SASS可以帮助我们更好地组织大CSS文件,更加便捷地开发和运行CSS文件,在Compass等类库的帮助下,我们将更加如虎添翼。

SASS特性

  • 完全兼容CSS3
  • 诸如变量、嵌套、混合(Mixins)之类的语言扩展
  • 操作颜色和其他的巨量实用函数
  • 类型控制语句的强大特性
  • 可以自定义的、格式良好的输出
  • 整合Firebug

SASS语法

SASS允许有两种语法:

  • SASS
    —sass是Sass的最初语法格式,通过tab键控制缩进的一种语法规则,而且对缩进要求非常严格,不带有任何的分号和大括号。以".sass"为扩展名。
  • SCSS
    —scss是Sass的新语法格式,从外形上来判断他和CSS长得一样,代码都包裹在一对大括号里,并且末尾技术处都有一个分号。以".scss"为扩展名。
    //使用SCSS    
    $baseFontsize:14px;  
    $Largefontsize:16px;  
    body{  
        font-size:$baseFontsize;
        p{
            font-size:$Largefontsize;
        }
    }

    //使用SASS
    $baseFontsize:14px
    $Largefontsize:16px
    body
        font-size:$baseFontsize
        p
            font-size:$Largefontsize

命令编译

命令编译时指使用电脑中的命令终端,通过Sass指令来编译Sass。

  • 单文件编译
    sass <要编译的Sass文件路径>/style.scss:<要输出的css文件路径>/style.css
  • 多文件编译
    sass sass/:css/ 

上面的命令表示将项目中“sass”文件夹中所有“.scss”(“.sass”)文件编译成“.css”文件,并且将这些 CSS 文件都放在项目中“css”文件夹中。

  • watch功能
    开启“watch”功能,对代码进行任何修改,都能自动检测代码的变化并直接编译
    sass --watch<要编译的Sass文件路径>/style.scss:<要输出的CSS文件路径>/style.css

输出方式

  1. 嵌套输出方式nested
    -编译时需带上参数“--style nested”
  2. 展开输出方式expanded
    -编译时需带上参数“--style expanded”
  3. 紧凑输出方式compact
    -编译时需带上参数“--style compact”
  4. 压缩输出方式compressed
    -编译时需带上参数“--style compressed”
nav {
  ul {
    margin: 0;
    padding: 0;
    list-style: none;
  }

  li { display: inline-block; }

  a {
    display: block;
    padding: 6px 12px;
    text-decoration: none;
  }
}

针对上边的CSS文件,采用不同的编译方式:

  • 嵌套方式
nav ul {  
  margin: 0;  
  padding: 0;
  list-style: none; }
nav li {
  display: inline-block; }
nav 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;
}

与nested方式类型,只是大括号在另起一行

  • 紧凑方式
nav ul { margin: 0; padding: 0; list-style: none; }
nav li { display: inline-block; }
nav a { display: block; padding: 6px 12px; text-decoration: none; }

类似于单行CSS样式格式

  • 压缩方式
nav ul{margin:0;padding:0;list-style:none}nav li{display:inline-block}nav a{display:block;padding:6px 12px;text-decoration:none}

压缩输出方式会去掉标准的Sass和CSS注释及空格。

SASS调试

浏览器支持“sourcemap”功能,可以实现在浏览器中直接调试sass文件。
如果不支持,需要在编译的时候添加“--sourecmap”参数:

sass --watch --scss --sourcemap style.scss:style.css

在Sass3.3版本之上,不需要添加这个参数也可以:

sass --watch style.scss:style.css
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容