sass和compass基础用法

一、基本命令

  • 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:cssFileDirectorycss文件转成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 sassAPPcompass编译
compass compile
compass compile --forcecompass监视
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'); // 11a-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;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/276284.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

字节面试官:如何实现Ajax并发请求控制

偷偷告诉你&#xff0c;点此抽奖送红包还送3本比红宝书还贵的书实现一个批量请求函数 multiRequest(urls, maxNum)&#xff0c;要求如下&#xff1a; • 要求最大并发数 maxNum • 每当有一个请求返回&#xff0c;就留下一个空位&#xff0c;可以增加新的请求 • 所有请求完成后…

制造行业电子化签约及印控一体化解决方案

当生产“智造化”、营销“数字化”成为趋势&#xff0c;生产制造型企业如何实现产品生产-销售全流程提速降本&#xff1f;生产制造型企业为了在生产、营销环节降低成本、提升效率&#xff0c;经营模式上常有如下特征&#xff1a;• 原料导向&#xff0c;多点协同生产&#xff1…

一起手写Vue3核心模块源码,掌握阅读源码的正确方法

最近和一个猎头聊天&#xff0c;说到现在前端供需脱节的境况。一方面用人方招不到想要的中高级前端&#xff0c;另一方面市场上有大量初级前端薪资要不上价。特别是用 Vue 框架的&#xff0c;因为好上手&#xff0c;所以很多人将 Vue 作为入门框架&#xff0c;但学得深的人并不…

2020 前端技术发展回顾

大家好&#xff0c;我是若川&#xff0c;今天给大家分享一篇来自阿里妈妈前端快爆的好文。另外&#xff0c;偷偷告诉你&#xff0c;截止今晚9点 点此抽奖送红包还送3本比红宝书还贵的书可以点击文章末尾阅读原文直达知乎链接&#xff0c;以下是正文2020 终究是一个不平凡的一年…

第一章知识点

第一章知识点 一&#xff1a;SQL语言 1&#xff0c;结构化查询语言&#xff0c;是关系数据库的标准语言 2&#xff0c;分类&#xff1a; 2.1&#xff1a;数据操作语言&#xff1a;DML&#xff1b;包括&#xff1a;即增删查改&#xff1b;insert&#xff0c;update&#xff0c;d…

2021年,推荐这几个优质公众号碎片化学习

2021 年了&#xff0c;前端技术日新月异&#xff0c;发展迅速&#xff0c;前端公众号是不是感觉越来越多了&#xff1f;在着辞旧迎新之际&#xff0c;这里盘点几个前端开发工程师 2021 年必须关注的优质公众号&#xff0c;希望对你有所帮助。大家可以像我一样&#xff0c;利用碎…

阿里云插件新版发布,多特性助力提升开发者体验

好消息&#xff01;阿里云 Cloud Toolkit 新版本于近日正式发布&#xff0c;推出了面向 IntelliJ 和 Eclipse 两个平台的新款插件&#xff0c;多个重大特性&#xff0c;持续提升开发者体验&#xff0c;本文将带大家快速预览该新版本。 本文只挑选下面三个重大特性进行解读&…

上一轮中奖信息公布

大家好&#xff0c;我是若川&#xff0c;抽奖活动其实挺耗时耗力的&#xff0c;尤其是留言和在看抽奖。比如我这篇文章写完就已经23:50了。特别想说的是&#xff1a;有126人点击了在看&#xff0c;但我的好友展示只有93人在看。说明还有30多人点击了在看&#xff0c;但忘记加我…

CentOS7Jenkins安装

2019独角兽企业重金招聘Python工程师标准>>> CentOS7Jenkins安装 2017年05月07日 20:20:32 申明霜 阅读数&#xff1a;13945 版权声明&#xff1a;本文为博主原创文章&#xff0c;未经博主允许不得转载。 https://blog.csdn.net/sms15732621690/article/details/713…

2020 全球 JS 现状调查报告

大家好&#xff0c;我是若川。偷偷告诉你&#xff0c;今天推文的第二条是在我的公众号回复「网盘」免费领取百度网盘会员&#xff0c;欢迎大家分享转发。给大家分享一篇好文&#xff0c;往期类似好文&#xff1a;2020 前端技术发展回顾2020年大前端技术趋势解读以下是正文&…

ie兼容响应式布局的实现总结 和 针对ie浏览器的CSS

参考链接&#xff1a;http://zhidao.baidu.com/link?urlbQioDKMnG_eQoE6dCxzd2hPtMyiB7phu6hBdOupn1Pjk1hV-ItXFZS5GDUBoH5qrfi9LXkUoSciXTiGN36G6LK 参考链接&#xff1a;http://blog.sina.com.cn/s/blog_601b97ee0101aszo.html ie浏览器hack .demo {padding:10px;padding:9…

group by 保留哪一条数据_使用R语言绘制一维数据统计图总结

加载数据 绘制茎叶图 绘制直方图 绘制概率密度曲线 绘制小提琴图 绘制箱线图 绘制小提琴图箱线图 集中趋势统计 分散程度 apply的使用加载数据模拟数据下载library(tidyverse) cjb <- read.csv("/home/wy/Downloads/cjb.csv",header TRUE,stringsAsFactors FALS…

npm安装和Vue运行

一、开始&#xff1a; 下载地址&#xff1a;http://nodejs.cn/download/ 下载安装&#xff1a; 直到 二、打开CMD,检查是否正常 在安装目录里新增两个文件夹 然后运行命令&#xff1a;如下图&#xff1a; npm config set prefix "D:\InstallSoftWare\nodejs\node_global&q…

Scott 32 岁前端年终总结,探寻另一种可能

今年一年都是飞快 这 10 年编程好时光&#xff0c;花费在不经意间&#xff0c;而立的第三年也即将用完&#xff1a;23 到 26 岁&#xff0c;花在了阿里&#xff0c;从入门到职业迷茫&#xff0c;27 到 29 岁&#xff0c;花在了创业&#xff0c;从热血到倒闭还钱&#xff0c;30 …

跨页数据传递的两种方式

选择具有PostBackUrl属性的三个控件Button、LinkButton、ImageButton。PostBackUrl属性的值就是投递的页面URL。 要在接收页面按对象的方式接收投递页面的表单中的值有两种方式&#xff1a; 1、PreviousPage.FindControl(“控件变量名”)&#xff0c;这个方法返回的是Control类…

嵌入式操作系统 NuttX 5.0 发布

Nuttx 是一个实时嵌入式操作系统&#xff08;RTOS&#xff09;&#xff0c;它有一个小巧是在微控制器的环境中使用。这是完全可扩展&#xff0c;从小型&#xff08;8位&#xff09;至中型嵌入式&#xff08;32位&#xff09;系统。它的目的还 在于要完全符合标准&#xff0c;完…

Windows下Mysql 的安装和卸载

2019独角兽企业重金招聘Python工程师标准>>> 一、安装 1、下载zip文件 2、解压&#xff0c;在bin目录下新建my.ini [mysql] # 设置mysql客户端默认字符集 default-character-setutf8 [mysqld] # 设置3306端口 port3306 # 设置mysql的安装目录 basedirC:\Program Fil…

现在学前端还来得及吗?总听人说饱和了

“前端已经饱和了&#xff0c;现在学前端没有前途了”每次听到这种论调我都气不打一处来。自己技艺不精&#xff0c;然后就说市场饱和了。是&#xff0c;现在的确不是那个会切个图&#xff0c;懂点htmlCSS就能找到工作的年代了。现在对前端的技术要求稍微高了点&#xff0c;但这…

DotNetNuke 5 C#版本解读之2--HTTP Modules

在前面文章里说明了DNN的架构&#xff0c;下面这个图应该说是更加能够全面的让你去了解它的结构&#xff1a; 如果你是个asp.net新手建议你看看前面这部分&#xff0c;因为它会向你介绍什么是http module,以及其他的一些概念。我想通过你读这篇文章来明白asp.net的机制&#xf…

用框架的你,可能早已忽略了这些事件API

DOMContentLoaded&#xff0c;load&#xff0c;beforeunload&#xff0c;unloadHTML 页面的生命周期包含三个重要事件&#xff1a;DOMContentLoaded —— 浏览器已完全加载 HTML&#xff0c;并构建了 DOM 树&#xff0c;但像 <img> 和样式表之类的外部资源可能尚未加载完…