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/ ...
随机推荐
- 【转】关于android的输入法弹出来 覆盖输入框的有关问题
今天发现一个问题,在录入信息页面.信息不多,但是输入法弹起后,内容已经超出页面,无滚动条,很不方便. 解决办法:在配置文件中,页面对应的Activity中添加 <activity android ...
- editplus 使用小技巧
1 editplus怎么设置tab键跳的字符数? Tools -> Preferences -> Files -> Settings & syntax -> Tab/I ...
- Python自带的日志模块logging的使用
import logging # 创建一个logger logger = logging.getLogger('cmccLogger') logger.setLevel(logging.DEB ...
- Windows Live Writer的Markdown插件
我新写了一个Windows Live Writer的Markdown插件,代码放在了github上. 介绍 这个项目是一个Windows Live Writer的Markdown插件.有了这个插件,你 ...
- BZOJ 1806 IOI2007 Miners 矿工配餐 动态规划
题目大意:将一个123序列拆分为两个子序列.定义每一个数的贡献值为以这个数结尾的长度最大为3的子串中不同数的数量,求贡献值和的最大值 令f[i][a1][a2][b1][b2]为前i个数分成两组,第一 ...
- java EE 学习
http://blog.csdn.net/liushuijinger/article/category/1342030/1
- AndroidStudio工程文件导入Jar包和So第三方库
AndroidStudio 导入Jar包和第三方So库 在android开发中,需要导入许多第三方的jar包和so库来支持,包括像许多第三方的支持平台--友盟,环信.融云.极光推送.微博.腾讯等第三方 ...
- nginx php7 配置 备用
yum install epel-* -y yum install -y wget unzip gcc gcc-c++ make zlib zlib-devel pcre pcre-devel lib ...
- table转list
DataTable数据集转换为List非泛型以及泛型方式 前言 DataTable是断开式的数据集合,所以一旦从数据库获取,就会在内存中创建一个数据的副本,以便使用.由于在实际项目中,经常会将 Dat ...
- maven占位符
maven占位符默认是${} 也可以自己指定. pom.xml配置如下: <plugin> <groupId>org.apache.maven.plugins</grou ...