Sass

基于ruby的一种将脚本解析成CSS的脚本语言。也可以说是一种预处理语言。

Sass在css的语法基础上增加了变量、嵌套、混合、继承、导入等高级功能。

使用Sass与Sass样式库(如compass)有助于更好地管理样式文件,更高效开发项目。

sass不适用花括号和分号,不被广为接受

而scss作为sass3引用的新语法,兼容了CSS3的同时,继承了Sass的强大功能,比较优秀

Sass的安装与使用:

1 安装ruby依赖:以下任选其一

2 打开VScode终端安装sass

  • gem install sass
  • gem install compass(compass是一种sass样式库)

3 编写sass代码,在指定的目录下编译成css文件

$w:50px
div
width: 50px
height: 50px
background-color: red

在指定目录下生成css文件:

格式:sass sassUrl  cssUrl

示例:sass  ./testSass/a.sass  ./testcss/a.css

4 在页面引入sass

其实是使用link标签引入sass生成的css文件

<link rel="stylesheet" href="../css/c.css">

5 效果

6 监听目录下sass变化并动态生成css文件到指定css目录

终端命令:

sass --watch  sass文件目录:css文件生成目录

示例:sass --watch ./testSass:./testCss

Scss

命令行:sass sccsPath  cssPath

例如:sass ./testScss/a.sccs  ./testcss/sa.css

标签选择器:

$_w:100px;
div{
width: $_w;
height: 100px;
background: red;
}

类选择器:

.div1{
width: $_w*3;
height: $_w*4;
background: purple;
}

&代表当前父标签,伪类选择器

$_w1: 100px;
div {
width: $_w1;
height: $_w1;
background-color: aqua;
// & is subClass : div
&:hover{
background-color: lightcoral;
}
}

伪元素选择器:

$w_1:100px;
div{
width: $_w;
height: $_w;
border: 1px solid #000;
&::after{
content: 'after element';
display: block;
width: $w_1;
height: $w_1;
background-color: aqua;
position: absolute;
left: 100px;
}
}

后代选择器:

$w_1:100px;
div{
span{
display: block;
position: absolute;
left: 100px;
background-color: pink;
}
}

子代选择器:

$w_1:100px;
div{
>span{
display: block;
position: absolute;
left: 100px;
background-color: pink;
}
}

相邻兄弟选择器: 元素1 + 兄弟元素(选中此元素,是元素1的后方相邻元素)

+只能选中当前元素后方相邻元素,只能选一个

~也表示兄弟选择器,区别是~可以选择该元素后方所有的同级元素

二者都不能选择该元素1前面的兄弟元素

$w_1: 100px;
div {
+ span {
display: block;
position: absolute;
left: $w_1;
background-color: pink;
}
}

相邻兄弟选择器:~  选择后方所有同级兄弟元素,只能是后方的

$w_1: 100px;
div {
~ span {
display: block;
position: absolute;
left: $w_1;
background-color: pink;
}
}
div{
&+.div1{
background-color: yellow;
}
}

选择元素的属性:

$_w :100px;
div{
width: $_w;
height: $_w;
background-color: red;
border: {
left: {
width: 10px;
style:solid;
color: pink;
};
};
}

导入:

@import "c";//导入同级目录下c.scss

混合器的使用:@maxin定义内容,@include在选择器里导入内容语句。如果是不同文件,在使用混合器之前,要将@maxin所在scss文件导入方可

注意:调用其他文件下的混合器,在include之前需要@import导入

@mixin setUL($_w,$_h){
width: $_w+px;
height: $_h+px;
background-color: aqua;
}
ul{
@include setUL(100,200);
}

混合器与条件判断if使用:

@mixin setP($_w:10,$_h:10){
@if $_w<50{
$_w:;
}
width:$_w+px;
height: $_h+px;
background: lightcoral;
}
p{
@include setP(1,100)
}

混合器子代继承

@import selector;

p{
>a{
@extend p;
display: block;
position: relative;
left: 100px;
background-color: lightcyan;
}
}

迭代器:

只包含start不包含end

for $var from start through(或者用to) end{

selector#{$var}{....}

}

@for $i from 1 through 6 {
.elem#{$i}{
display: inline-block;
width: 50px;
height: 50px;
background-color: lightcyan;
}
}

Sass&Scss入门 选择器 混合器 导入 条件判断 迭代的更多相关文章

  1. python入门(11)条件判断和循环

    python入门(11)条件判断和循环 条件判断 计算机之所以能做很多自动化的任务,因为它可以自己做条件判断. 比如,输入用户年龄,根据年龄打印不同的内容,在Python程序中,用if语句实现: ag ...

  2. Python 入门(五)条件判断和循环

    if语句 计算机之所以能做很多自动化的任务,因为它可以自己做条件判断. 比如,输入用户年龄,根据年龄打印不同的内容,在Python程序中,可以用if语句实现: age = 20 if age > ...

  3. 【重点】Shell入门教程:流程控制(2)条件判断的写法

    第三节:条件判断的写法 if条件判断中,if的语法结构中的“条件判断”可以有多种形式.测试结果是真是假,就看其传回的值是否为0. 条件测试的写法,有以下10种: 1.执行某个命令的结果 这里的命令,可 ...

  4. 【重点】Shell入门教程:流程控制(3)条件判断式的真假值

    之前曾提到,在Bash中什么是真什么是假,是以命令的结束状态是否为0来做判断.传回0,即为真:传回非0,即为假. 在Bash中,这种可以影响程序流程的式子,称为条件判断式.判断式的操作数分成“单元”及 ...

  5. Python入门基础之条件判断、循环、dict和set

    Python之if语句 比如,输入用户年龄,根据年龄打印不同的内容,在Python程序中,可以用if语句实现: age = 20 if age >= 18: print 'your age is ...

  6. Python之条件判断和循环(入门4)

    转载请标明出处: http://www.cnblogs.com/why168888/p/6407755.html 本文出自:[Edwin博客园] Python之条件判断和循环 1. Python之if ...

  7. python条件判断if/else - python基础入门(8)

    生活中我们总是面临各种选择,选择不同,结果也不同,不管我们是否愿意,总会有结果,有的快乐,也有的痛苦…… 鲁迅说:人只要有钱,烦恼就会减掉90%以上,情商智商也会提高,更不会乱发火!(关键是:钱怎么来 ...

  8. laravel 中CSS 预编译语言 Sass 快速入门教程

    CSS 预编译语言概述 CSS 作为一门样式语言,语法简单,易于上手,但是由于不具备常规编程语言提供的变量.函数.继承等机制,因此很容易写出大量没有逻辑.难以复用和扩展的代码,在日常开发使用中,如果没 ...

  9. sass 使用入门教程

    我们都知道,css没有变量,也没有条件语句,在开发过程中,难免有些麻烦,因此有了CSS预处理器(css preprocessor),Sass便是其中之一. 一.什么是Sass Sass (Syntac ...

随机推荐

  1. java面试记录二:spring加载流程、springmvc请求流程、spring事务失效、synchronized和volatile、JMM和JVM模型、二分查找的实现、垃圾收集器、控制台顺序打印ABC的三种线程实现

    注:部分答案引用网络文章 简答题 1.Spring项目启动后的加载流程 (1)使用spring框架的web项目,在tomcat下,是根据web.xml来启动的.web.xml中负责配置启动spring ...

  2. 51Nod 1091 线段的重叠 (贪心)

    X轴上有N条线段,每条线段包括1个起点和终点.线段的重叠是这样来算的,[10 20]和[12 25]的重叠部分为[12 20]. 给出N条线段的起点和终点,从中选出2条线段,这两条线段的重叠部分是最长 ...

  3. CSS一些特殊图形

    CSS一些特殊图形 CSS绘制三角形 通过控制元素的border属性可以实现三角形效果; 首先来设置4个边框, 为50px solid [color] color设置成不同的颜色值看一下效果 < ...

  4. 天兔修改登录页的title

    1.将 /opt/lampp/htdocs/lepus/application/views/login.php 文件中 第6行 <title><?php echo $this-> ...

  5. 2020牛客寒假算法基础集训营3 G.牛牛的Link Power II (树状数组维护前缀和)

    https://ac.nowcoder.com/acm/contest/3004/G 发现每个“1”对于它本身位置产生的影响贡献为0,对前面的“1”有产生贡献,对后面的"1"也产生 ...

  6. linux分区命令parted的用法

    parted的适用场景 创建操作大于2T的分区 一般情况下,我们都是选择使用fdisk工具来进行分区,但是目前在实际生产环境中使用的磁盘空间越来越大,呈TiB级别增长:而常用的fdisk这个工具对分区 ...

  7. phpstorm实用技巧

    1.切换php代码版本提示 1.1找到External Libraries右键点击(configure PHP Include Paths) 1.2切换提示版本(在这里切换版本)确定即可 2.生成ge ...

  8. ApiBehaviorOptions 统一模型验证配置不生效

    ApiBehaviorOptions 的统一模型验证配置一定要放到(.AddMvc)后面.

  9. HTML /和./的区别 - Web开发

    "/"访问根目录 例1 https://www.cnblogs.com/test 里有 <a href="/Edsuns"></a> 则 ...

  10. JS高级---递归

    递归 递归: 函数中调用函数自己, 此时就是递归, 递归一定要有结束的条件   var i = 0; function f1() { i++; if (i < 5) { f1(); } cons ...