zoukankan      html  css  js  c++  java
  • Scss基础用法

    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}- 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);
    }
  • 相关阅读:
    前方高能!!!一大泼干货来袭。。。。
    spring-cloud-gateway(三)自定义lb实现
    spring-cloud-gateway(二)es代理功能需求
    spring-cloud-gateway(一)代码分析
    一个spark MurmurHash map类加器
    hbase RegionTooBusyException报错异常处理
    hbase HexStringSplit 预分区
    spark读写hbase的几种方式,及读写相关问题
    实现elasticsearch网关,兼容不同版本es,滚动升级-功能验证开发
    k8s平台集成kong ingress 布署konga集成ui
  • 原文地址:https://www.cnblogs.com/Michelle20180227/p/9121186.html
Copyright © 2011-2022 走看看