资讯专栏INFORMATION COLUMN

sass和compass基础用法

paraller / 1013人阅读

摘要:一基本命令都是通过安装,以下是一些基础的命令移除的镜像地址添加淘宝的镜像查看镜像单文件转换命令单文件监听命令监听会自动编译文件夹监听命令文件转成文件在线转换工具运行命令行帮助文档,可以获得所有的配置选项表示解析后的

一、基本命令

sass都是通过gem安装,以下是一些基础的命令

移除ruby的镜像地址
gem sources --remove https://rubygems.org/

添加淘宝的镜像 
gem source -a http://ruby.taobao.org

查看镜像 gem source -v

单文件转换命令
sass style.scss style.css

单文件监听命令(监听会自动编译)
sass --watch style.scss:style.css

文件夹监听命令
sass --watch sassFileDirectory:cssFileDirectory

css文件转成sass/scss文件(在线转换工具css2sass)
sass-convert style.css style.sass
sass-convert style.css style.scss

运行命令行帮助文档,可以获得所有的配置选项
sass -h

--style表示解析后的css是什么格式,有四种取值分别为:nested,expanded,compact,compressed
sass --watch style.scss:style.css --style compact

----------------以下是compass-----------

compass创建一个编译目录,会生成config.rb文件,里面是一些配置
compass create sassAPP

compass编译
compass compile
compass compile --force

compass监视
compass watch
compass watch --force
二、sass基础语法 1、变量
// 变量默认值,默认20px,但赋值后为18px
$fontsize:18px;
$fontsize:20px !default;
p {
  font-size: $fontsize; //18px
}

// 多值变量:可以直接使用,也可以当做一个数组从中取值
$paddings:7px 10px 9px 8px;
$many:(color:red,font-size:24px,border:solid 1px blue); // 像是一个数组
.btn{
  padding:$paddings; // 直接使用
  padding-left:nth($paddings,2); // 当做数组,从中取值
  background-color:map_get($many,color); // 当做数组,从中取值
  border:map_get($many,border); // 当做数组,从中取值
}
// 编译后
.btn {
  padding: 7px 10px 9px 8px;
  padding-left: 10px;
  background-color: red;
  border: solid 1px blue;
}

// 局部变量和全局变量
body{
  // 局部变量,不能用在footer中
  $color:red;
  color:$color;
  // 全局变量
  $font-size:16px !global;
}
footer{
  // color:$color; // 不可以使用局部变量
  font-size: $font-size; // 可以使用全局变量
}

// 变量用在选择器上
$className:main;
.#{$className}{
  margin:10px;
  padding:5px;
}

// 变量中的下划线和减号意义相同
$text-info:blue;
$text_info:red;
section{
  color:$text-info;
}
2、嵌套和继承
body{
  background-color:red;
  // 选择器嵌套
  header{
    background-color:green;
  }

  // 属性嵌套
  footer{
    background:{
      color:red;
      size:100% 50%;
    }
  }

  a{
    // 引用父选择器
    &:hover{
      color:blue;
    }
    &.contain{
      background-color:yellow;
    }
   }
}

// 继承与多继承
.alert{
  background-color: #FED;
}
.small{
  font-size:12px;
}
.alert-info{
  @extend .alert;
  @extend .small;
  // 用以下方法代替
  // @extend .alert,.small;
}

// 链式继承
.one{
  border:solid 1px red;
}
.two{
  @extend .one;
  color:blue;
}
.three{
  @extend .two;
  border-radius:5px;
}

// 占位选择器 不会生成得到css中
%alert{
  color:green;
}
.alert-danger{
  @extend %alert;
}
3、数值类型和mixin
// 数字类型
$n1:1.2;
$n2:12;
$n3:14px;
.body{
  font-size:$n3;
}
// 字符串类型
$s1:container;
$s2:"container";
$s3:"container";
.#{$s1}{
  font-size:$n3;
}
// 布尔类型
$bt:true;
$bf:false;

// null类型
$null:null;
body{
  @if($null==null){
    color:red;
  }
}
// 颜色类型
$c1:blue;
$c2:#fff;
$c3:rgba(255,255,0,0.5);
body{
  color:$c3;
}

// 加减乘除
$width1:12px;
$width2:13px;
body{
  width:$width1+$width2;
  .header{
    width:$width1 -$width2;
  }
}
a:before{
  content:"A"+bc;
}
a:before{
  content:A+"bc";
}
p{
  padding:3px + 4px auto;
}


$version:3;
p:before{
  // 使用变量的方法
  content:"hello,sass #{$version}"
}
p{
  font-size:20px/10px;
  font-size:(20px/10px);
  width:$width2/2;
  height:round($width2)/2;
}

// 引用片段
@mixin cont{
  color:red;
  font-size:18px;
}
// 函数功能,:blue可以去掉
@mixin cont1($color:blue){
  color:$color;
}
// 多参数函数
@mixin cont2($color,$font-size){
  color:$color;
  font-size:$font-size;
}
body{
  @include cont;
  @include cont1(green);
  @include cont2(green,20px);
}
p{
  @include cont2($font-size:good,$color:green);
}

// 多数值函数,变量个数可变
@mixin box-shadow($box-shadow...){
  -webkit-box-shadow: $box-shadow;
  -moz-box-shadow: $box-shadow;
  box-shadow: $box-shadow;
}
body{
  @include box-shadow(2px 2px 0px blue,-2px -2px 0px green);
}

// 内容传递
@mixin style-for-iphone{
  @media only screen and (max-width:768px) and (min-width:240px){
    margin: 10px;
    @content;
  }
}
@include style-for-iphone{
  font-size:24px;
  background-color:#fff;
}
// 编译后
@media only screen and (max-width: 768px) and (min-width: 240px) {
  margin: 10px;
  font-size: 24px;
  background-color: #fff;
}
4、函数、调试(一般也用不上)
// 自定义函数
@function double($width){
  @return $width*2;
}
.container{
  width:double(5px);
}

$color:rgb(255,0,255);
body{
  color:$color;
  background-color:rgba(255,255,0,0.5);
  border-color:rgba($color,0.5);
  width:500px;
  height:500px;
  p{
    // 颜色加深函数
    color:darken($color,5);
    background-color:lighten($color,5);
    // 奇葩函数,谁会这么用?
    z-index:str-length("hello world"); // 11
    a-index:str-index("abcdefg","d"); // 4
  }
}
// 测试判断所用,控制台輸出
// @debug "This is a debug test";
// @warn "Warn";
// @error "Error";
@function Three($width){
  @if($width>3){
    @error "$width is error";
  }
  @return $width*3;
}
body{
  width:#{Three(2)}px;; // 6px
}

@function getIndex($layer:default){
  $zIndexMap:(default:1,modal:100,dropdown:500,grid:300);
  $z-index:1;
  @if map-has_key($zIndexMap,$layer) {
    $z-index:map_get($zIndexMap,$layer);
  }
  @return $z-index;
}
p{
  z-index:getIndex(modal);
  z-index:getIndex(abc);
}
// 编译后
p {
  z-index: 100;
  z-index: 1;
}
5、条件语句、循环
// if三目运算
$screenWidth:600px;
body{
  color:if($screenWidth>768px,blue,red);
}

// if条件语句
body{
  @if $screenWidth>768px{
    color:red;
  }@else if $screenWidth<500px{
    color:blue;
  }@else{
    color:green;
  }
}

// for循环 through包含5,而to不包含5
@for $i from 1 through 5{
  span#{$i}{
    width:20%*$i;
  }
}

// while循环
$j:5;
@while $j>0{
  .div#{$j}{
    width:20%*$j;
  }
  $j: $j - 2;
}

// each常规遍历
$k:1;
@each $c in red blue green yellow{
  .section#{$k}{
    background-color:$c;
  }
  $k:$k+1;
}

// each list遍历
@each $key,$color in (default,blue),(info,green),(danger,red){
  .text-#{$key}{
    background-color:$color;
  }
}

// each map遍历
@each $key,$color in (default:blue,info:green,danger:red){
  .label-#{$key}{
    background-color:$color;
  }
}


@function screenDivide($Num){
  $num:$Num;
  $map:(defaultvalue:0);
  @for $i from 1 to $num{
    $mapValue:(#{$i}:percentage(1/$num)*$i);
    $map:map-merge($map,$mapValue);
  }
  $map:map_remove($map,defaultvalue);
  @return $map;
}
@each $key,$value in screenDivide(5){
  .slider#{$key}{
    width:$value;
  }
}

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/117225.html

相关文章

  • 前端利器:SASS基础Compass入门

    摘要:在吸取了的一些特性基础上,有了大幅改进,也就是现在的。嵌套极大程度上降低了选择器名称和属性的重复书写。选择器嵌套选择器嵌套是指从一个选择器中嵌套子选择器,来实现选择器的继承关系。也已经成为的一个标配组件。 SASS是Syntactically Awesome Stylesheete Sass的缩写,它是css的一个开发工具,提供了很多便利和简单的语法,让css看起来更像是一门...

    娣辩孩 评论0 收藏0
  • Compass创建者Chris Eppstein:真正的CSS框架是如何工作的

    摘要:当我的补丁被拒绝了之后,我想要指出一个方向真正的框架是如何工作的。发起这项捐助有我的个人原因在里面,我的父亲在年被确诊为患有一种罕见的成年人形式的线粒体疾病。正是一个经历了如此过程的产品。 非商业转载请注明作译者、出处,并保留本文的原始链接:http://www.ituring.com.cn/article/120792 Chris Eppstein,Compass框架的创建...

    BigTomato 评论0 收藏0
  • 使用compass自动合并css雪碧图(css sprite)

    摘要:使用雪碧图,能够减少页面的请求数降低图片占用的字节,以此来达到提升页面访问速度的目的。也正是因为这一点,导致很多开发者懒于使用雪碧图。本文就介绍下怎样使用来自动合并雪碧图。生成的每个雪碧图默认的规则是目录名图片名。 css雪碧图又叫css精灵或css sprite,是一种背景图片的拼合技术。使用css雪碧图,能够减少页面的请求数、降低图片占用的字节,以此来达到提升页面访问速度的目的。但...

    刘永祥 评论0 收藏0
  • [ 前端实习日记 ] 构建静态页面基础架构

    以前我们敲静态页面都是写好html,css, js,然后再去刷新浏览器,艾尼马又不行,有重新写过再刷新,一个页面下来按chrl+r的次数可让你的键盘多活好几天,要不会刷新快捷按钮那不得手残了都。 后来,grunt,gulp等工具应运而生,当然它们不止这个功能,但却很好地减轻了我们的负担。这篇文章介绍一些如何使用这些工具使构建页面变得简单高效。这只是个人的目前在用的不成熟的方案,更专业的还请参考...

    lidashuang 评论0 收藏0
  • [Sass]-Sass入门

    摘要:未编译样式多继承链式继承占位选择器编译后样式中使用声明混合,可以传递参数,参数名以符号开始,多个参数以逗号分开,也可以给参数设置默认值。 初识Sass SASS简介 sass是一种css预处理器,用专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件。Sass是CSS3的扩展,它增加了嵌套规则,变量,mixins,选择器继承等等。Sass生成格式良好的CSS,使样式表更易于组...

    godiscoder 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<