前端利器:SASS基础与Compass入门
SASS是Syntactically Awesome Stylesheete
Sass的缩写,它是css的一个开发工具,提供了很多便利和简单的语法,让css看起来更像是一门语言,这种特性也被称为“css预编译”。它的主要设计思想是让我们可以按照编程的思路编写自己的样式,然后通过“编译器”生成我们所需要的css文件。
当然,SASS只是css预编译工具中的一种,类似的工具还有Less、stylus等,SASS起初语法采用缩进排列形式,但对于设计师来说既不直观还容易出现错误。在吸取了Less的一些特性基础上,SASS3.0有了大幅改进,也就是现在的SCSS。
为什么使用SASS/SCSS
- 易维护,更方便的定制
对于一个大型或者稍微有规模的UI来说,如果需要替换下整体风格,或者是某个字体的像素值,比如我们经常会遇到panel,window以及portal共用一个背景色,这个时候按照常规的方式,我们需要一个个定位到元素使用的class,然后逐个替换,SASS提供了变量的方式,你可以把某个样式作为一个变量,然后各个class引用这个变量即可,修改时,我们只需修改对应的变量。
对于编程人员的友好 - 对于一个没有前端基础的编程人员,写css样式是一件非常痛苦的事情,他们会感觉到各种约束,为什么我不能定一个变量来避免那些类似“变量”的重复书写?为什么我不能继承上个class的样式定义?。。。SASS/SCSS正是帮编程人员解开了这些疑惑,让css看起来更像是一门编程语言。
- 效率的提升
对于一个前端开发人员来说,我不熟悉编程,也不关注css是否具有的一些编程语言特性,但这不是你放弃他的理由,css3的发展,加之主流浏览器的兼容性不一,很多浏览器都有自己的兼容hack,很多时候我们需要针对不同的浏览器写一堆的hack,这种浪费时间的重复劳动就交给SASS处理去吧!
安装与使用
SASS最早来源于Haml项目,但这个工程饱受诟病,很多人认为它使html失去语义化的特性,因此,并没有广泛的得到推广,而源自于它的SASS受到一致的认可,SASS基于Ruby编写,也是Ruby On Rails的主力插件。尽管如此,你无需担心自己没有Ruby基础,你需要的只是一个Ruby环境(现在已经有人把SASS移植到python编译环境下了)。
- Ruby的下载地址: https://www.ruby-lang.org/zhX 31Xcn/ window下可以直接下载安装包
- 安装SASS,安装完ruby之后,你就可以直接在命令行执行下面的命令(注册为环境变量):
>gem install sass
注:由于国内网络原因,可能会导致gem安装插件时失败,此时可以将gem源切换为淘宝的ruby镜像站 http://ruby.taobao.org/
3. 使用
SASS文件的后缀为.scss,可以使用下面的命令将scss文件编译为最终使用的css文件:
sass demo.scss
或者指定css文件名
sass demo.scss product.css
基本语法
1. 变量
SASS支持变量的定义,你可以使用$来定义一个变量,这样我们就可以把一些公用的样式定义为一个变量,在使用时直接引用即可:
$white:#fff;
$font12:12px;
.menu{
color: $white;
font-size: $font12;
}
编译后:
.menu {
color: white;
font-size: 12px;
}
2 .嵌套
SASS支持两种嵌套方式:选择器嵌套和属性嵌套。嵌套极大程度上降低了选择器名称和属性的重复书写。
- 选择器嵌套
选择器嵌套是指从一个选择器中嵌套子选择器,来实现选择器的继承关系。
.header{
.logo{
display: block;
border: none;
}
ul li{
line-break: normal;
}
}
编译后:
.header .logo {
display: block;
border: none;
}
.header ul li {
line-break: normal;
}
两者对比不难发现,省去了很大一部分的选择器的层级声明。
可以通过&来表示父元素选择器,比如我们声明一个a标签的样式:
a{
text-decoration: none;
&:hover{
color: #007998;
}
}
编译后:
a {
text-decoration: none;
}
a:hover {
color: #007998;
}
- 属性嵌套
属性嵌套,是指将带有相同前缀单词的属性提出来,作为一个公有的属性,嵌套进其他属性,就像很多姓氏一样的人,把这些人姓氏只记一次,后面跟上不同的名字。
h3{
font:{
size:26px;
weight:normal;
family:arial
}
}
编译后:
h3 {
font-size: 26px;
font-weight: normal;
font-family: arial;
}
当然实际情况font定义可能更简洁些,这里只是做一个示例。
3. 函数
SASS中,你可以对属性值进行简单的运算, 比如:
$white:#fff;
$font12:12px;
.newsize{
font-size: $font12 + 2;
color:$white - #007998;
}
编译后生成:
.newsize {
font-size: 14px;
color: #ff8667;
}
当然除了最基本的加减乘除运算函数,SASS还提供了很多其他有趣的函数,像我们最常用的颜色函数lighten(减淡)和darken(加深)。
.lgt{
color: lighten($black,10%);
background-color: darken($white,50%);
}
编译后可以得到一个运算好的颜色值:
.lgt {
color: #1a1a1a;
background-color: gray;
}
更多的函数信息,请查看 SASS官方函数大全
4. 混合
SASS的混合是一个非常值得你去尝试的特性,如果你对这个概念不太清楚,那么你可以认为他就是一个模板的宏定义,而且这个宏还能接收参数。
@mixin box-shadow{
-webkit-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15);
-moz-box-shadow:inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15);
box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15);
}
.funny-box{
@include box-shadow;
}
编译后:
.funny-box {
-webkit-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15);
-moz-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15);
box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15);
}
带参数的mixin:
@mixin border-radius($circle:50px){
-webkit-border-radius: $circle;
-moz-border-radius: $circle;
border-radius: $circle;
}
.circle{
@include border-radius(10px);
}
$circle:50px
为默认参数,可以通过传递参数来覆盖默认参数,编译后效果如下:
.circle {
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
}
除此之外,minxin还支持多个参数,也支持类似于java中的String...类型的多个值的传递。
5. 继承
既然SASS看起来像一门语言了,那么其他语言的一些基本特性,也应该是其所具备的,SASS不孚众望,具备了一个简单的继承特性,使用这个特性需要关键字@extend
。
.pclass{
border: 4px solid #ff9aa9;
}
.subclass{
@extend .pclass;
border-width: 2px;
}
编译后:
.pclass, .subclass {
border: 4px solid #ff9aa9;
}
.subclass {
border-width: 2px;
}
使用compass
介绍完SASS的一些基本入门知识点后,你是否有想尝试下的冲动呢?工欲善其事,必先利其器;这里简单介绍下一个开发中经常使用的SASS工具compass,compass是SASS团队成员开发的,compass是对SASS的一个封装,目的是为开发者提供一些丰富的mixin组件以及一些实用的工具模块。compass也已经成为ruby on rails的一个标配组件。
安装
安装依然使用ruby gem安装方式,参照前面安装sass过程,gem命令如下:
gem install compass
现在安装compass时,一般都附带安装上了sass组件,也就是说你可以跳过前面安装sass的流程了。
getting start
工程的创建
compass create yourpj;
此时会在目录下生成三个文件:
- config.rb这是个配置文件,主要指定sass源文件地址,以及编译后生成的css文件地址
- sass存放sass源文件
- stylesheets存放编译后生成的css
已有工程的初始化
对于已经创建好的工程,要想支持compass编译,只需要初始化一下就可以(切换到指定目录下):
compass init
编译
完成sass的开发后,只需要运行下编译命令:
compass compile
compile支持多种模式的编译,详细信息可通过 compass compile -h
查看。
每次编写sass完成后,都需要手动运行下编译命令,能不能自动编译呢?那当然是可以的,只需要对当前工程添加watch监视,如下:
compass watch
组件模块
前面我们提到compass提供了便捷的组件模块,我们来一起看看有哪些常用的组件吧:
- reset 浏览器样式重置模块,减少不同浏览器间的差异性
- css3 css3命令模块
- layout 布局模块
- typography 版式模块
- utilities 工具类
reset使用:
@import "compass/reset";
这样就会在css中生成重置样式了,不用我们再自己定义重置样式了。
css3使用:
@import "compass/css3";
这是个绝对好用的特性,我们知道由于浏览器对css3支持的差异性,我们很多时候需要写一堆针对不同浏览器前缀样式,着实很烦人,css3命令模块帮我们解决了这个问题,我们只需include相应样式定义即可,compass会自动为我们生成针对不同浏览器的样式定义:
@import "compass/css3";
.circle {
@include border-radius(5px);
}
编译后:
.circle {
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
-o-border-radius: 5px;
-ms-border-radius: 5px;
-khtml-border-radius: 5px;
border-radius: 5px;
}
就写到这吧,其他特性慢慢探讨吧!
前端利器:SASS基础与Compass入门的更多相关文章
- [转]前端利器:SASS基础与Compass入门
[转]前端利器:SASS基础与Compass入门 SASS是Syntactically Awesome Stylesheete Sass的缩写,它是css的一个开发工具,提供了很多便利和简单的语法,让 ...
- 好程序员web前端分享HTML基础篇
好程序员web前端分享HTML基础篇,最近遇到很多新手,都会问,如果要学web前端开发,需要学什么?难不难学啊?多久能入门之类的问题?那么今天好程序员就先来给大家分享一下web前端学习路线:HTML基 ...
- 第87节:Java中的Bootstrap基础与SQL入门
第87节:Java中的Bootstrap基础与SQL入门 前言复习 什么是JQ? : write less do more 写更少的代码,做更多的事 找出所有兄弟: $("div" ...
- 老师的blog整理 .网络编程部分 .网络编程部分 前端部分 django基础部分
老师的blog整理 .网络编程部分 .网络编程部分 前端部分 django基础部分 老师的blog整理 python基础部分: 宝哥blog: https://www.cnblogs.com/gu ...
- Web大前端时代之:HTML5+CSS3入门系列
准备来一波新技术,待续.... Old: 联系源码:https://github.com/dunitian/LoTHTML5 文档下载:https://github.com/dunitian/LoTD ...
- 07. Web大前端时代之:HTML5+CSS3入门系列~H5 地理位置
Web大前端时代之:HTML5+CSS3入门系列:http://www.cnblogs.com/dunitian/p/5121725.html 源码:https://github.com/duniti ...
- 01.Web大前端时代之:HTML5+CSS3入门系列~初识HTML5
Web大前端时代之:HTML5+CSS3入门系列:http://www.cnblogs.com/dunitian/p/5121725.html 文档申明 <!--文档类型申明,html代表是ht ...
- 02.Web大前端时代之:HTML5+CSS3入门系列~H5结构元素
Web大前端时代之:HTML5+CSS3入门系列:http://www.cnblogs.com/dunitian/p/5121725.html 1.结构元素 可以理解为语义话标记,比如:以前这么写&l ...
- 03.Web大前端时代之:HTML5+CSS3入门系列~H5功能元素
Web大前端时代之:HTML5+CSS3入门系列:http://www.cnblogs.com/dunitian/p/5121725.html 2.功能元素 1.hgroup 对网页或区段(secti ...
随机推荐
- mfc_Demo
内涵图
- SpringBoot之springfox(Swagger) (ApiDoc接口文档)
Springfox的前身是swagger-springmvc,是一个开源的API doc框架,可以将我们的Controller的方法以文档的形式展现,基于Swagger. 官网地址:http://sp ...
- EditText 自动格式化电话电话号码
需要格式化的格式为:xxx xxxx xxxx 有两种方式:1.为监听当前输入的长度,当长度为第四位,九位的时候,在原内容上追加空格.(from stackOverFlow)2.每次输入后,格式化当前 ...
- Django views 中 View decorators
decorators(装饰器) 1. require_http_methods 在django.views.decorators.http中,可以用来限制请求的权限. require_http_met ...
- JS和CSS关于大小写的区分
方法: document.getElementById("xx").style.xxx中的所有属性是什么 盒子标签和属性对照 CSS语法(不区分大小写) JavaScript语法( ...
- AIDL学习
(转自)可以参见:http://www.2cto.com/kf/201406/312244.html 1.为什么要有AIDL? 无论学什么东西,最先得弄明白为什么要有这个东西,不要说存在即是合理,存在 ...
- stl 存放对象析构问题
vector内数据使用结构体的话是深拷贝,vector内的数据会拷贝一份保存,vector内数据不会丢失.如果vector内数据是指针的话是进行浅拷贝,数据超出作用域后会自动析构,vector内所指向 ...
- 执行powershell脚本
打开powershell运行窗口: powershell.exe C:\Users\Administrator\Desktop\a.ps1 -a $a. -a $a : vbs脚本路径(如 C:\h ...
- jQuery图片渐变特效的简单实现
(document).ready(function() {(document).ready(function() {("div.baba").mouseleave(function ...
- Windows程序设计(第五版)学习:第三章 窗口与消息
第三章 窗口与消息 1,windows窗口过程:应用程序所创建的每一个窗口都有一个与之关联的窗口过程,用于处理传递给窗口的消息. 2,窗口依据窗口类来创建.窗口类标识了用于处理传递给窗口的消息 ...