其他分享
首页 > 其他分享> > 十分钟轻易学会Sass

十分钟轻易学会Sass

作者:互联网

文章目录

官网

引言

什么是Sass?

Sass的原理

安装

编译Sass

VS Code中使用Sass

1. 现在 VS Code 商店中,搜索 easy sass,然后安装
2. 修改VS Code 的配置, 点击管理,找到文本编辑器,点击 在settings.json中编辑

"easysass.compileAfterSave": true,
  "easysass.formats": [ //nested:嵌套缩进的 css 代码。//expanded:没有缩进的、
  //扩展的css代码。//compact:简洁格式的 css 代码。//compressed:压缩后的 css 代码
        {
            "format": "expanded",
            "extension": ".css"
        },
        {
            "format": "compressed",
            "extension": ".min.css"
        }
    ],
    "easysass.targetDir": "./css" 
    //保存编译时的路径,会在你编译的这个文件当前下的 css 文件中转换 css 文件,需要手动添加这个css 文件夹

使用

1.注释

//       单行注释(静默注释)不会被编译到 css 文件里面
/* */    多行注释 会在 xxx.css 中编译,  min.css 则不会
/*! */   强制注释,在任何版本下都会被保留

2.使用变量

1. 定义变量用 “$” 符替代


$color:yellow;
$a123:green;
$top:top;

2. 特殊变量,比如和css属性混在一起,为了能解析变量,把这个变量用 #{} 包起来

<style>
	div{
		width:100px;
		height:200px;
		border-#{$top}:12px solid green;  // $top 在上面定义变量时定义的
	}
</style>

3. 全局变量

<style>
	p{
		$abc:80px;
	}
	
	div{
		font-size:$abc; // 无法使用
	}
	
	在花括符内定义的变量在其它或括符内访问不到,如果想成为全局变量,
	在定义这个变量的后面加上 !global
	
	p{
		$abc:80px !global;
	}
</style>

3.默认变量值

$link-color:blue;
$link-color:red;

<style>
	a {
		color: $link-color; // red
	}
</style>
$bb:red !default;// 红色为默认值

<style>
	div {
		width:100px;
		height:100px;
		font-color:$bb; // red
		$bb:blue; // 此时,就把默认颜色改为 蓝色了
		font-color:$bb; // blue
	}
</style>

4.CSS

4-1.嵌套CSS 规则

#content article h1 { color: #333 }
#content article p { margin-bottom: 1.4em }
#content aside { background-color: #EEE }
#content {
  article {
    h1 { color: #333 }
    p { margin-bottom: 1.4em }
  }
  aside { background-color: #EEE }
}
article a {
  color: blue;
  &:hover { color: red }
}

4-2.群组选择器的嵌套

<style>
	.container {
  		h1, h2, h3 {margin-bottom: .8em}
	}
	
	.container h1, .container h2, .container h3 { 
		margin-bottom: .8em 
	}
	
	nav, aside {
  		a {
  			color: blue
  		}
	}

	nav a, aside a {
		color: blue
	}
</style>

4-3.子组合选择器和同层组合选择器:> +和~

article section { margin: 5px }  // 会选择article下的所有命中section选择器的元素

article > section { border: 1px solid #ccc } // 只会选择article下紧跟着的子元素中命中section选择器的元素。

header + p { font-size: 1.1em } // header元素后紧跟的p元素

article ~ article { border-top: 1px dashed #ccc } // 选择所有跟在article后的同层article元素,不管它们之间隔了多少其他元素

4-4.嵌套属性

nav {
  border: {
  	style: solid;
  	width: 1px;
  	color: #ccc;
  }
}

nav {
  border: 1px solid #ccc {
  	left: 0px;
  	right: 0px;
  }
}

nav {
  border-style: solid;
  border-width: 1px;
  border-color: #ccc;
}

5.混合 @mixin @include

@mixin border{
	border:1px solid red;
}

#div{
	@include border;  // 在 #div 就可以使用了 @mixin 定义的代码
}

6.继承 @extend

.btn{
	width:100px;
}

.dd{
	@extend .btn;  // 继承了.tbn 里面的属性  width:100px;
	height:50px;
}

7.引入 @import

假如现在这是 a.scss 文件,我们在里面编辑以下代码:
// a.scss
@charset="utf-8";
*{
	padding:0px;
	margin:0px;
}



假如现在在b.scss文件中,我们可以引入 a.scss文件
// b.scss
@import "a.scss"

8.if判断

$a = red;

.box{
	@if $a == red{

	}@else if $a ==blue{
		
	}@else{

	}
}

9.循环

1. @for循环 (through包含结束位置 , to不包含结束位置)

$count: 12;
//包含结束位置
@for $i from 1 through $count{
    li:nth-child(#{$i}){
        width: 100px / 12 * $i;
    }
    // $i = 1,2,3,4,5,6,7,8,9,10,11,12
}


//不包含结束位置
@for $i from 1 to $count{
    li:nth-child(#{$i}){
        width: 100px / 12 * $i;
    }
    // $i = 1,2,3,4,5,6,7,8,9,10,11
}

2. @each

$icons: success warning error primary info;
@each $icon in $icons{
    #box li:nth-child(#{$icon}){
        background: url(images/#{$icon}.png) no-repeat;
    }
}

3. @while

$i : 6;
@while $i > 0 {
    li:nth-child(#{$i}){
        font-size: #{$i*16}px;
    }
     $i : $i - 1;
}

10.函数 @function

$colors:(red:red,light:white,dark:black);
@function color($key){
	@if not map-has-key($colors,$key){

		@warn "警告,gulp不会终端"
		@error "会终止监听"
	}
	@return map-get($colors,$key);
}

//函数调用
body{
	background-color:color(red);
}


标签:轻易,Sass,color,十分钟,CSS,article,选择器,css
来源: https://blog.csdn.net/L_u_c_k_y_m_a_n/article/details/117319220