博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Scss基础用法
阅读量:5334 次
发布时间:2019-06-15

本文共 2247 字,大约阅读时间需要 7 分钟。

Scss基础用法

 

一、注释用法:

(1)//comment:该注释只是在.scss源文件中有,编译后的css文件中没有。

(2)/! /:重要注释,任何style的css文件中都会有,一般放置css文件版权说明等信息。

(3)/ /:该注释在compressed的style的css中没有,其他style的css文件都会含有。

 

二、变量:

1.一般以$开头,有作用域限制

$color: red;.div{
background-color: $color; }

 

2.若子选择器中定义的变量想成为全局变量,可以用!global

.div{
$width: 5px !global; width: $width;}.p{
width: $width;}

 

3.嵌套引用,需#{}进行包裹

$left: left;.div{
border-#{$left}-width: 5px; }

 

4.计算

$left: 20px;.div{
margin-left: $left + 12px; margin-top: $left / 2;}

 

三、选择器

1.选择器嵌套(允许属性嵌套)

.div{
.span{ height: 12px; } .p{
border: {      color: red;    } }}

 

2.引用父元素(使用&符号)

.div{
&:hover{ cursor: pointer; }}

 

四、代码复用

1.继承(若在div2后再加一个div1,也会影响div2的属性)

.div1{
font-size: 14px;}.div2{
@extend .div1; color: red;}

 

2.引用外部的scss文件(文件路径建议用相对路径)

@import  ‘ ./test.scss’;

 

3.Mixin与Include

//使用@mixin命令,定义一个代码块@mixin left {
  float: left;  margin-left: 5px;}//使用@include命令,调用这个mixin代码块div {
  @include left;}

 

五、参数

eg1:

@mixin common($value1, $value2, $defaultValue: 5px){
display: block; margin-left: $value1; margin-right: $value2; padding: $defaultValue;}.div1{
font-size: 8px; @include common(11px, 13px, 15px);}.div2{
font-size: 8px; @include common(11px, 13px);}

 

eg2:

//生成浏览器前缀。  @mixin rounded($vert, $horz, $radius: 10px) {
    border-#{$vert}-#{
$horz}-radius: $radius;    -moz-border-radius-#{
$vert}#{
$horz}: $radius;    -webkit-border-#{
$vert}-#{
$horz}-radius: $radius;  }//使用的时候调用:  #navbar li {
@include rounded(top, left); }  #footer {
@include rounded(top, left, 5px); }

 

六、条件语句

可以用@if(){}来判断,也可以用@if(){}@else来判断

@if lightness($color) > 30% {
  background-color: #000;} @else {
  background-color: #fff;}

 

七、循环语句

1.for循环

@for $i from 1 to 10 {
  .border-#{$i} {
    border: #{$i}px solid blue;  }}

 

2.while循环

$i: 6; @while $i > 0 {
  .item-#{$i} {
width: 2em * $i; }  $i: $i - 2;}

 

3.each(类似于for)

@each $member in a, b, c, d {
  .#{$member} {
    background-image: url("/image/#{$member}.jpg");  }}

 

八、函数

可以自定义函数

@function double($n) {
  @return $n * 2;}#sidebar {
  width: double(5px);}

 

转载于:https://www.cnblogs.com/Michelle20180227/p/9121186.html

你可能感兴趣的文章
【转】oracle的分析函数over
查看>>
java之适配器模式
查看>>
字典练习
查看>>
hdu 4496(并查集逆向添边)
查看>>
hdu 5437(优先队列模拟)
查看>>
(转)POJ推荐50题
查看>>
无法定位序数4369于动态链接库libeay32.dll
查看>>
手把手实现腾讯qq拖拽删去效果(一)
查看>>
子父类不同属性代码执行顺序
查看>>
dbcp 1.4 底层连接断开时内存泄露bug
查看>>
关于密码
查看>>
ASP.NET 导出PPT
查看>>
Git忽略规则及.gitignore规则不生效的解决办法
查看>>
How to fix the sources list
查看>>
Eclipse的数据库插件
查看>>
mysql简单学习
查看>>
嵌入式操作系统
查看>>
URI和URL的区别
查看>>
UI---startup--jquery
查看>>
echart使用总结
查看>>