Maison >interface Web >js tutoriel >Première utilisation du SASS

Première utilisation du SASS

php中世界最好的语言
php中世界最好的语言original
2018-03-19 13:52:381740parcourir

Cette fois, je vais vous présenter la première utilisation du SASS. Quelles sont les précautions lors de la première utilisation du SASS. Ce qui suit est un cas pratique, jetons un coup d'œil.

Première expérience avec les balises SASS

(séparées par des espaces) : sass scss css


L'environnement de compilation
nécessite Ruby pour. être installé, après cela, vous devez ouvrir Start Command Prompt with Ruby et exécuter

gem install sass

2. Compilation en ligne de commande

sass /style.scss:/style.css

compilation multi-fichiers (doit utiliser --watch ? Je ne l'ajoute pas de toute façon, la montre signalera une erreur)

sass --watch sass/:css/

Activer la montre

sass --watch /style.scss:/style.css

Méthode de sortie--style [nested(末尾花括号不换行)|expanded(完全展开)|compact(单行)|compressed(压缩)]

sass --watch sass/:css/ --style compressed

3. La syntaxe de base

(1)

est similaire à moins.

nav {
    color: blue;
    li {
        color: yellow;
        a {
            color: red;
            header & {
                color: green;
            }
        }
    }
}

Après compilation

nav {
  color: blue;
}
nav li {
  color: yellow;
}
nav li a {
  color: red;
}
header nav li a {
  color: green;
}
  • Les attributs sont imbriqués (même préfixe d'attribut), et les attributs peuvent être ajoutés après le préfixe deux-points

.box {
    font: 12px/24px {
        size: 12px;
        weight: bold;
    }
}

Après compilation

.box { font: 12px/24px; font-size: 12px; font-weight: bold; }
  • Imbrication de pseudo-classes, tout comme less

.clearfix {
    &:before,
    &:after {
        content: "";
        display: table;
    }
    &:after {
        clear: both;
        overflow: hidden;
    }
}

Compilé après

.clearfix:before, .clearfix:after {
  content: "";
  display: table;
}
.clearfix:after {
  clear: both;
  overflow: hidden;
}
  • le sélecteur parent & peut être utilisé comme premier caractère du sélecteur, comme

.btn {
    padding: 4px 12px;
    font-size: 16px;
    border: 1px solid #ddd;
    color: #333;
    &-primary {
        border-color: #ff5f00;
        background: #ff5f00;
        color: #fff;
    }
}

après compilation

.btn, .btn-primary { padding: 4px 12px; font-size: 16px; border: 1px solid #ddd; color: #333; }
.btn-primary { border-color: #ff5f00; background: #ff5f00; color: #fff; }

(2). Le commentaire

/**/ n'apparaîtra pas dans le fichier compilé
// n'apparaîtra pas

// 方向
/*方向*/
$d: "right";
.box {
    @extend %border-#{$d};
}
/*位置*/

Après compilation

.box {
  border-right: 2px solid #ddd;
}
/*方向*/
/*位置*/

(3) Variables

$[变量名]: [值]
Portée au niveau du bloc
. !globalLa déclaration peut convertir les variables locales en variables globales
Les variables par défaut ; les variables ordinaires écraseront les variables par défaut

$size: 16px;
$size: 14px !default;
p.p-1 {
    font-size: $size;
}

Après la compilationp.p-1{font-size:16px}

(4). Opération

+, -, *, /, %
, = Peut également être utilisée pour des opérations numériques ==, != Peut être utilisée pour tous les types de données
Les opérations avec des unités différentes ne peuvent pas être effectué
Peut être effectué Concaténation de chaînes ; et le fait qu'il y ait des guillemets ou non est déterminé par le côté gauche
La division doit être dans une expression mathématique et deux attributs communs doivent être mis entre parenthèses, tels que

.box {
    width: (100px / 2);
}

Après la compilation

.box {
  width: 50px;
}
  • Les variables enveloppées dans des instructions d'interpolation n'effectuent pas d'opérations de division

p {
    $font-size: 12px;
    $line-height: 30px;
    font: #{$font-size}/#{$line-height};
}

Après compilation

p { font: 12px/30px; }
  • Segmentation du calcul des couleurs (selon le rouge, le vert et le bleu)
    Fonction couleur
    Parmi fade-in($color, $amount) et autres méthodes, le paramètre de couleur ne peut être la rgba() couleur, qui est différente du moins

Première utilisation du SASS

Mélange

  • est utilisé pour définir des styles réutilisables. Notez que la syntaxe n'inclut pas de points et que les paramètres sont par défaut. La valeur est également la même que moins
    @mixin [mixin-name]([$param1, $param2: default-value]) { ... }
    . 🎜>@include [mixin-name](value1, value2);

  • Pour les paramètres indéfinis, utilisez
  • , tel que

    ...

@mixin box-shadow($shadows...) { 
    -moz-box-shadow: $shadows; 
    -webkit-box-shadow: $shadows; 
    box-shadow: $shadows; 
}
(6). >

  • @extend .[class] peut également hériter de n'importe quelle définition des sélecteurs pour des éléments uniques, tels que

  • @extend a:hover;

    Après la compilation,
.btn {
    border: 1px solid #999;
    padding: 4px 12px;
    font-size: 14px;
    background: #ddd;
    color: #333;
}
.btn-primary {
    background: #ff5f00;
    color: #fff;
    @extend .btn;
}
espace réservé

est déclaré avec des espaces réservés Le code ne sera compilé que s'il est appelé par
.btn, .btn-primary {
  border: 1px solid #999;
  padding: 4px 12px;
  font-size: 14px;
  background: #ddd;
  color: #333;
}
.btn-primary {
  background: #ff5f00;
  color: #fff;
}

Le même style sera être combiné via % pour réduire la quantité de code
@extend
Après compilation,

%box-padding {
    padding: 4px 12px;
}
.box {
    font-size: 14px;
    @extend %box-padding;
}
.box-2 {
    font-size: 18px;
    @extend %box-padding;
}

(7)Interpolation

.box, .box-2 {
  padding: 4px 12px;
}
.box {
  font-size: 14px;
}
.box-2 {
  font-size: 18px;
}

Vous. peut utiliser la variable dans le sélecteur ou le nom de l'attribut via l'instruction d'interpolation

, qui peut être utilisée dans

, #{}, les commentaires multilignes
#{$[param]}@each après compilation@extend

$border-properties: (border);
@mixin set-border($direction, $val) {
    @each $prop in $border-properties {
        #{$prop}-#{$direction}: $val;
    }
}
.box {
    @include set-border(left, 1px solid #ddd);
}

après compilation

.box {
  border-right: 2px solid #ddd;
}

(8). 导入

  • @import可以导入多个文件,比如@import "rounded-corners", "text-shadow";

  • 导入文件可以通过url()的方式使用插值语句#{},比如@import url("http://fonts.googleapis.com/css?family=\#{$family}");

  • 如果想使一个sass文件只作为导入文件,不进行编译,在文件名前加_即可,比如文件命名为_colors.scss,使用@import "colors";导入,注意文件夹下不能再有colors.scss文件。

  • 可以用在嵌套中,作用域就只在当前嵌套中了,很赞;但是不可以在混合指令 (mixin) 或控制指令 (control directives) 中嵌套 @import。

(9). 媒体查询 @media

  • 用法同css

  • 可以写在嵌套中,编译后将会编译在最外层,且里面的选择器会是嵌套时候的选择器
    比如

.sidebar {
    width: 300px;
    @media screen and (orientation: landscape) {
        width: 500px;
    }
}
.sidebar { width: 300px; }
@media screen and (orientation: landscape) { .sidebar { width: 500px; } }
  • media的查询条件可以使用插值语句

  • media的查询条件可以嵌套

(10). @at-root

  • 将嵌套的选择器提升到当前文档最顶层, 比如

.parent {
    font-size: 14px;
    @at-root .child-a {
        font-size: 16px;
        @at-root .child-c {
            font-size: 18px;
        }
    }
    .child-b {
        font-size: 12px;
    }
}
.parent { font-size: 14px; }
.child-a { font-size: 16px; }
.child-c { font-size: 18px; }
.parent .child-b { font-size: 12px; }
  • @at-root (without: [directive1 directive2 ...])可以排除前面的指令

  • 括号后面不能有选择器,没有括号必须有选择器

@media .print {
    .page {
        width: 8in;
        @at-root (without: media) {
            color: red;
        }
    }
}
// 没有without
@media print {
    .page {
        width: 8in;
        @at-root .p {
            color: red;
        }
    }
}
@media .print { .page { width: 8in; } }
.page { color: red; }
@media print { .page { width: 8in; }
  .p { color: red; } }

(11). 控制指令

  • 主要与混合指令 (mixin) 配合使用,
    这是less中所没有的,less通过其它方式可以实现类似的效果,比如循环,less可以通过递归配合when关键字来实现:.loop(@counter) when (@counter > 0) { .loop((@counter - 1)); }

  • @if 表达式返回值不是 false 或者 null 时,执行 {} 内的样式,同样还有@else if@else

  • @for 语法:@for $var from <start> through <end></end></start> 或者 @for $var from <start> to <end></end></start>
    <start></start><end></end> 必须为整数
    through 包含 <start></start><end></end> 的值,而 to 只包含 <start></start>

  • @each 语法: $var in <list></list>
    <list></list> 值为列表
    比如

$arr: a, b, c, d, e;
@each $img in $arr {
    .box-#{$img} {
        background: url('/img/#{$img}.png') no-repeat;
    }
}
.box-a { background: url(&quot;/img/a.png&quot;) no-repeat; }
.box-b { background: url(&quot;/img/b.png&quot;) no-repeat; }
.box-c { background: url(&quot;/img/c.png&quot;) no-repeat; }
.box-d { background: url(&quot;/img/d.png&quot;) no-repeat; }
.box-e { background: url(&quot;/img/e.png&quot;) no-repeat; }
$list: (aa, pen), (bb, apple), (cc, bag);
@each $var, $img in $list {
    .box-#{$var} {
        background: url('/img/#{$img}.png') no-repeat;
    }
}
.box-aa { background: url(&quot;/img/pen.png&quot;) no-repeat; }
.box-bb { background: url(&quot;/img/apple.png&quot;) no-repeat; }
.box-cc { background: url(&quot;/img/bag.png&quot;) no-repeat; }

使用map数组或许更为明了:

$list-2: (aaa: yellow, bbb: blue, ccc: red);
@each $key, $color in $list-2 {
    .box-#{$key} {
        background: #{$color};
    }
}
.box-aaa { background: yellow; }
.box-bbb { background: blue; }
.box-ccc { background: red; }
  • @while 循环,语法:@while [conditions] { ... }

(12). 其它

  • @debug 可以输出信息到编译器

  • @warn 将SassScript表达式的值打印到标准错误输出流。

  • @error 抛出SassScript表达式的值作为致命错误

  • @function 自定义函数

@function [function-name]([params]) {
    @return [value];
}

The end...    Last updated by: Jehorn, Mar 13, 2018, 12:10 PM

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

Connaissance de base du HTML dans le front-end

Position du modèle CSS float box

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn