Sass学习
1.1下载地址:
http://rubyinstaller.org/downloads
2.1 安装
SASS是Ruby语言写的,但是两者的语法没有关系。不懂Ruby,照样使用。只是必须先安装Ruby,然后再安装SASS。
假定你已经安装好了Ruby,接着在命令行输入下面的命令:
gem install sass
然后,就可以使用了。
2.2 使用
SASS文件就是普通的文本文件,里面可以直接使用CSS语法。文件后缀名是.scss,意思为Sassy CSS。
下面的命令,可以在屏幕上显示.scss文件转化的css代码。(假设文件名为test。)
sass test.scss
如果要将显示结果保存成文件,后面再跟一个.css文件名。
sass test.scss test.css
SASS提供四个编译风格的选项:
* nested:嵌套缩进的css代码,它是默认值。
* expanded:没有缩进的、扩展的css代码。
* compact:简洁格式的css代码。
* compressed:压缩后的css代码。
生产环境当中,一般使用最后一个选项。
sass --style compressed test.sass test.css
你也可以让SASS监听某个文件或目录,一旦源文件有变动,就自动生成编译后的版本。
// watch a file
sass --watch input.scss:output.css
// watch a directory
sass --watch app/sass:public/stylesheets
SASS的官方网站,提供了一个在线转换器。你可以在那里,试运行下面的各种例子。
三、基本用法
变量
SASS允许使用变量,所有变量以$开头。
Sass源代码:
$blue:#1875e7;
div{
color:$blue;
} $side:left;
/*asassdf*/
.rounded{
.round{
border-#{$side}-radius:5px;
} } /*计算能力*/
$var:2;
body{
margin: (14px/2);
top:50px + 100px;
right:$var * 20%;
} /*嵌套*/
div h1{
color:red;
} /*也可以写成这样*/
/*属性的嵌套必须要在属性后成加上冒号*/
p{
border:{
color:red; }
}
/*关于注释:
又斜杠是在css文件中是不显示的;
C++方式注释的方法会留在CSS文件中;
*/ /*继承*/
.class1{
margin:0 auto;
border:1px solid #000;
}
.class2{
@extend .class1;
font-size:120%;
} /*Mixin 宏的使用*/
@mixin left{ //定义mixin宏
float:left;
margin-left:10px;
} div{
@include left; //@include 用于引用minxin宏; } /*带参数的minxin宏*/
@mixin left($value:20px){
float:left;
margin-right:$value;
} //使用带参数的mixin宏;
div{
@include left(40px); } /*Sass高级语法*/
//@if 语句的使用;
p{
@if 1 + 1 == 2{
border:1px solid #000;
} @if 3 < 2{
border:2px solid #fff; }
}
//@else 语句的使用;
/*
@function linghtness($value){
@return $value;
}
$color:20%;
@if linghtness($color) > 30%{
background-color:#000;
}@else{
background-color:#fff;
}*/ //for 语句的使用;
@for $i from 1 to 5 {
.itme-#{$i} {width:100px; height:100px; }
} //while语句 $i:6; @while $i > 0 {
.itme-#{$i} {width: 2em * $i;}
$i:$i - 2; } //each命令
@each $member in a, b, c, d, f{ .#{$member}{
background-image:url("../images/#{$member}.jpg");
}
}
对应生成的CSS文件:
@charset "UTF-8";
div {
color: #1875e7;
} /*asassdf*/
.rounded .round {
border-left-radius: 5px;
} /*计算能力*/
body {
margin: 7px;
top: 150px;
right: 40%;
} /*嵌套*/
div h1 {
color: red;
} /*也可以写成这样*/
/*属性的嵌套必须要在属性后成加上冒号*/
p {
border-color: red;
} /*关于注释:
又斜杠是在css文件中是不显示的;
C++方式注释的方法会留在CSS文件中;
*/
/*继承*/
.class1, .class2 {
margin: 0 auto;
border: 1px solid #000;
} .class2 {
font-size: 120%;
} /*Mixin 宏的使用*/
div {
float: left;
margin-left: 10px;
} /*带参数的minxin宏*/
div {
float: left;
margin-right: 40px;
} /*Sass高级语法*/
p {
border: 1px solid #000;
} /*
@function linghtness($value){
@return $value;
}
$color:20%;
@if linghtness($color) > 30%{
background-color:#000;
}@else{
background-color:#fff;
}*/
.itme-1 {
width: 100px;
height: 100px;
} .itme-2 {
width: 100px;
height: 100px;
} .itme-3 {
width: 100px;
height: 100px;
} .itme-4 {
width: 100px;
height: 100px;
} .itme-6 {
width: 12em;
} .itme-4 {
width: 8em;
} .itme-2 {
width: 4em;
} .a {
background-image: url("../images/a.jpg");
} .b {
background-image: url("../images/b.jpg");
} .c {
background-image: url("../images/c.jpg");
} .d {
background-image: url("../images/d.jpg");
} .f {
background-image: url("../images/f.jpg");
}
Sass学习的更多相关文章
- Sass学习笔记(补充)
阅读目录 1. Sass和SCSS的区别 2. @while循环 3. @at-root 4. @content 5. 凸显注释 6. CSS输出样式 7. 重置浏览器样式 8. Sass调试和@de ...
- Sass学习第一天
Sass学习 网站学习地址: Sass中文网:https://www.sass.hk/docs/#t7-3 Airen的博客:https://www.w3cplus.com/preprocessor/ ...
- Sass学习笔记之入门篇
Sass又名SCSS,是CSS预处理器之一,,它能用来清晰地.结构化地描述文件样式,有着比普通 CSS 更加强大的功能. Sass 能够提供更简洁.更优雅的语法,同时提供多种功能来创建可维护和管理的样 ...
- gulp + webpack + sass 学习
笔记: new webpack.optimize.CommonsChunkPlugin 核心作用是抽离公共代码,chunks:['index.js','main.js'] 另一个作用就是单独生成一个j ...
- sass学习笔记1
less在处理CSS动画时,非常恶心,决定转向sass了.sass诞生得比less早,只是因为它是ruby写的,因此受众面够少.但我们不需要自己下编译器或使用命令行,我们可以koala这神器 首先几个 ...
- sass学习(2)——关于变量
定义一个sass变量 可以说,变量是一个编程语言的基础.所以对于sass来说,变量肯定是浓墨重彩的其中一笔,当然函数也是.那我们如何声明定义一个sass的变量呢? 变量的符号$ 变量名称 变量的值 那 ...
- sass学习(1)——了解sass
为什么要选择sass 我们在手写css中,会遇到很多很麻烦的问题.倒不是一些技术的问题,而是工程量的问题.例如,如何可以代替难记的16进制颜色,如何可以让层次更清晰,还有重复的代码该如何偷懒.其实这一 ...
- sass 学习
本来看了阮一峰和于江水两位老师的博客,有看了ionic自带的sass文件,原以为自己已经是很熟悉,精通了.可是我居然连ruby都不知道真实惭愧啊,辛亏看了www.sass.hk 我想这篇官方文档肯定 ...
- 菜鸟的 Sass 学习笔记
介绍 sass 是什么?? 在sass的官网,它是这么形容给自己的 Sass is the most mature, stable, and powerful professional grade C ...
- SASS学习笔记!(持续学习中..)
工具 : koala 学习网址 : http://www.w3cplus.com/sassguide/syntax.html http://sass-lang.com/documentation/ ...
随机推荐
- Java GC专家系列1:理解Java垃圾回收
了解Java的垃圾回收(GC)原理能给我们带来什么好处?对于软件工程师来说,满足技术好奇心可算是一个,但重要的是理解GC能帮忙我们更好的编写Java应用程序. 上面是我个人的主观的看法,但我相信熟练掌 ...
- 宁波Uber优步司机奖励政策(1月25日~1月31日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- tomacat 配置ssl协议
1.首先用jdk自带的工具keytool生成一个"服务器证书" a.命令行进入$JAVA_HOME/bin目录($JAVA_HOME为jdk的安装目录) b.输入:keytool ...
- Circle - SGU 130(递推)
题目大意:一个圆上有2K个点,用K个线把他们连接起来,求出这些线最少可以把这个圆分成P部分,有N种分割方法.输出N和P. 分析:分割线一定是相互不相交的线,所以可以把这写分成两部分,f[i] += f ...
- JVM内存管理和JVM垃圾回收机制
JVM内存管理和JVM垃圾回收机制(1) 这里向大家描述一下JVM学习笔记之JVM内存管理和JVM垃圾回收的概念,JVM内存结构由堆.栈.本地方法栈.方法区等部分组成,另外JVM分别对新生代和旧生代采 ...
- JAVA IO详解
[案例1]创建一个新文件 1 2 3 4 5 6 7 8 9 10 11 import java.io.*; class hello{ public static void main(Stri ...
- SQL ID自增列从1开始重新排序 分类: SQL Server 2014-05-19 14:46 652人阅读 评论(0) 收藏
数据库中把ID自增长重置成1: 一般做法:(太麻烦) 复制表数据->删除原表.新建一张表->粘贴: 新方法: 数据库中:新建查询->复制.粘贴一下代码->修改表名,执行即可(先 ...
- (三)phpcms之文件目录
刚刚接触phpcms,先从它的目录结构说起. 如下图所示,是phpcms的主目录结构: 其中api是接口目录,这个接口不是很明白.大概其是把别的内容加入进来,比如论坛啊什么的. caches是缓存文件 ...
- json字符串、json对象、数组 三者之间的转换
json字符串转化成json对象 // jquery的方法 var jsonObj = $.parseJSON(jsonStr) //js 的方法 var jsonObj = JSON.parse(j ...
- Android 举例说明自己的定义Camera图片和预览,以及前后摄像头切换
如何调用本地图片,并调用系统拍摄的图像上一博文解释(http://blog.csdn.net/a123demi/article/details/40003695)的功能. 而本博文将通过实例实现自己定 ...