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

Première utilisation du SASS

php中世界最好的语言
Libérer: 2018-03-19 13:52:38
original
1767 Les gens l'ont consulté

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
Copier après la connexion

2. Compilation en ligne de commande

sass /style.scss:/style.css
Copier après la connexion

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

sass --watch sass/:css/
Copier après la connexion

Activer la montre

sass --watch /style.scss:/style.css
Copier après la connexion

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

sass --watch sass/:css/ --style compressed
Copier après la connexion

3. La syntaxe de base

(1)

est similaire à moins.

nav {
    color: blue;
    li {
        color: yellow;
        a {
            color: red;
            header & {
                color: green;
            }
        }
    }
}
Copier après la connexion

Après compilation

nav {
  color: blue;
}
nav li {
  color: yellow;
}
nav li a {
  color: red;
}
header nav li a {
  color: green;
}
Copier après la connexion
  • 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;
    }
}
Copier après la connexion

Après compilation

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

.clearfix {
    &:before,
    &:after {
        content: "";
        display: table;
    }
    &:after {
        clear: both;
        overflow: hidden;
    }
}
Copier après la connexion

Compilé après

.clearfix:before, .clearfix:after {
  content: "";
  display: table;
}
.clearfix:after {
  clear: both;
  overflow: hidden;
}
Copier après la connexion
  • 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;
    }
}
Copier après la connexion

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; }
Copier après la connexion

(2). Le commentaire

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

// 方向
/*方向*/
$d: "right";
.box {
    @extend %border-#{$d};
}
/*位置*/
Copier après la connexion

Après compilation

.box {
  border-right: 2px solid #ddd;
}
/*方向*/
/*位置*/
Copier après la connexion

(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;
}
Copier après la connexion

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);
}
Copier après la connexion

Après la compilation

.box {
  width: 50px;
}
Copier après la connexion
  • 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};
}
Copier après la connexion

Après compilation

p { font: 12px/30px; }
Copier après la connexion
  • 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; 
}
Copier après la connexion
(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;
}
Copier après la connexion
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;
}
Copier après la connexion

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;
}
Copier après la connexion

(7)Interpolation

.box, .box-2 {
  padding: 4px 12px;
}
.box {
  font-size: 14px;
}
.box-2 {
  font-size: 18px;
}
Copier après la connexion

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);
}
Copier après la connexion

après compilation

.box {
  border-right: 2px solid #ddd;
}
Copier après la connexion

(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;
    }
}
Copier après la connexion
.sidebar { width: 300px; }
@media screen and (orientation: landscape) { .sidebar { width: 500px; } }
Copier après la connexion
  • 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;
    }
}
Copier après la connexion
.parent { font-size: 14px; }
.child-a { font-size: 16px; }
.child-c { font-size: 18px; }
.parent .child-b { font-size: 12px; }
Copier après la connexion
  • @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;
        }
    }
}
Copier après la connexion
@media .print { .page { width: 8in; } }
.page { color: red; }
@media print { .page { width: 8in; }
  .p { color: red; } }
Copier après la connexion

(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;
    }
}
Copier après la connexion
.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; }
Copier après la connexion
$list: (aa, pen), (bb, apple), (cc, bag);
@each $var, $img in $list {
    .box-#{$var} {
        background: url('/img/#{$img}.png') no-repeat;
    }
}
Copier après la connexion
.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; }
Copier après la connexion

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

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

(12). 其它

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

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

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

  • @function 自定义函数

@function [function-name]([params]) {
    @return [value];
}
Copier après la connexion

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal