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中的资源文件
最近复习Android资源文件的内容,留下点记录以备后用. Android中的资源主要是指存放在应用程序或者Framework相应包下/res中的内容.它们可以被本地化,如果必要的话会被编译成二进制文 ...
- Google Picasa
本博文的主要内容有 .Google Picasa的下载 .Google Picasa的安装 .Google Picasa的使用 Google 的免费图片管理工具Picasa,数秒钟内就可找到并欣赏计算 ...
- Milk Patterns - poj 3261 (求重复k次的最长子串)
题目大意:给你一个数组,求这个数组里面至少重复k次的子串. 分析:后缀数组的练手题目...不过给的数字比较大,可以先离散化处理一下即可. 代码如下: ===================== ...
- oracle空表导不出来
在oracle 11g r2中,使用exp有时候会导不出空的表,原因是这些表没有分配空间,手工分配空间即可导出. ----查询当前用户下的所有空表: select table_name from us ...
- http://c7sky.com/works/css3slides/#1
http://c7sky.com/works/css3slides/#1 css3 学习
- java第四周学习
这一周学习的还是面向对象的方法和应用 Java中方法的使用和注意事项 如果没有返回值,就不允许通过return关键字返回结果 方法中不允许嵌套使用 Return返回值只允许返回一个值,不允许返回多个 ...
- 登陆用户怎样获取验证码和保存用户到cookie中
User表: User.java package user.domain; import java.io.Serializable; import java.util.Date; public cla ...
- 【设计模式 - 14】之命令模式(Command)
1 模式简介 命令模式的定义: 命令模式将命令封装成对象,从而使调用一个命令变为调用一个对象的指定方法. 命令模式的优点: 1) 降低了系统耦合度: 2) 新的命 ...
- HUNNU--湖师大--11407--It Is Cold
[F] It Is Cold Dr. Ziad Najem is known as the godfather of the ACPC. When the regional contest was ...
- 在Linux下用netstat查看网络状态、端口状态
在Linux下用netstat查看网络状态.端口状态 在linux一般使用netstat 来查看系统端口使用情况步. netstat命令是一个监控TCP/IP网络的非常有用的工具,它可以显示路由表.实 ...