标签:sass css3 移动开发 模块化 hybrid app
Ionic移动开发框架使用sass生成css,极大地提高了写css地效率和模块化程度,使得css开发不再是一件苦差事。ionic框架默认css是通过SASS生成的,同样你可以方便的写自己的sass,扩展或覆盖默认的css,最终只生成一个css文件!我们项目已经完全使用sass了,不再直接写css。结合gulp自动化工具,极大的提高了开发效率和质量。
CSS基本上是设计师的工具,不是程序员的工具。在程序员眼里,CSS是一件很麻烦的东西。它没有变量,也没有条件语句,只是一行行单纯的描述,写起来相当费事。很自然地,有人就开始为CSS加入编程元素,这被叫做"CSS预处理器"(css preprocessor)。它的基本思想是,用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件。各种"CSS预处理器"之中,比较流行的是LESS和SASS,个人更喜欢SASS。
下面Sass用法部分参考了 阮一峰 http://www.ruanyifeng.com/blog/2012/06/sass.html
</pre><pre name="code" class="html"> gem install sass
然后,就可以使用了。
sass test.scss test.css
sass --style compressed test.sass test.css
// watch a file sass --watch input.scss:output.css // watch a directory sass --watch app/sass:public/stylesheets
$blue : #1875e7; div { color : $blue; }
如果变量需要镶嵌在字符串之中,就必须需要写在#{}之中。
$side : left; .rounded { border-#{$side}-radius: 5px; }
body { margin: (14px/2); top: 50px + 100px; right: $var * 10%; }
div h1 { color : red; }
可以写成:
div { hi { color:red; } }
p { border: { color: red; } }
注意,border后面必须加上冒号。
在嵌套的代码块内,可以使用$引用父元素。比如a:hover伪类,可以写成:
a { &:hover { color: #ffb3ff; } }
/*! 重要注释! */
@mixin left { float: left; margin-left: 10px; }
使用@include命令,调用这个mixin。
div { @include left; }
@mixin left($value: 10px) { float: left; margin-right: $value; }
div { @include left(20px); }
下面是一个mixin的实例,用来生成浏览器前缀。
@mixin rounded($vert, $horz, $radius: 10px) { border-#{$vert}-#{$horz}-radius: $radius; -moz-border-radius-#{$vert}#{$horz}: $radius; -webkit-border-#{$vert}-#{$horz}-radius: $radius; }
使用的时候,可以像下面这样调用:
#navbar li { @include rounded(top, left); } #footer { @include rounded(top, left, 5px); }
lighten(#cc3, 10%) // #d6d65c darken(#cc3, 10%) // #a3a329 grayscale(#cc3) // #808080 complement(#cc3) // #33c
@import "path/filename.scss";
如果插入的是.css文件,则等同于css的import命令。
@import "foo.css";
p { @if 1 + 1 == 2 { border: 1px solid; } @if 5 < 3 { border: 2px dotted; } }
配套的还有@else命令:
@if lightness($color) > 30% { background-color: #000; } @else { background-color: #fff; }
@for $i from 1 to 10 { .border-#{$i} { border: #{$i}px solid blue; } }
也支持while循环:
$i: 6; @while $i > 0 { .item-#{$i} { width: 2em * $i; } $i: $i - 2; }
each命令,作用与for类似:
@each $member in a, b, c, d { .#{$member} { background-image: url("/image/#{$member}.jpg"); } }
@function double($n) { @return $n * 2; } #sidebar { width: double(5px); }
阮大侠的转载到此结束,下面我讲下gulp-sass的知识,gulp是一个比较新的js自动构建工具,目标是取代grunt,成为最流行的js构建工具。ionic框架集成gulp sass插件处理sass。
安装sass,需要先安装gulp,都是通过nodejs的npm管理的。在ionic项目目录下运行下面的命令安装相关插件
npm install gulp npm install gulp-sass npm install gulp-minify-css npm install gulp-concat npm install gulp-rename
ionic 用了上面这些gulp插件,各插件的功能看名字应该就能才出来,安装完插件后,运行下面的命令
gulp sass gulp watch #sass文件修改后自动编译
本篇就讲这么多了。
转载请注明转自 offbye涛声依旧-全端技术博客
SASS在HTML5移动应用开发中的应用,布布扣,bubuko.com
标签:sass css3 移动开发 模块化 hybrid app
原文地址:http://blog.csdn.net/offbye/article/details/38293223