Sass (Stylesheet-Sprache)

Sass
Sass-Logo
Basisdaten
Erscheinungsjahr:2007
Designer:Hampton Catlin
Entwickler:Natalie Weizenbaum, Chris Eppstein
Aktuelle Version:1.52.3[1]  (9. Juni 2022)
Beeinflusst von:CSS, YAML
Beeinflusste:Less, Stylus
Betriebssystem:Plattformunabhängig
Lizenz:MIT-Lizenz
sass-lang.com

Sass (Syntactically Awesome Stylesheets) ist eine Stylesheet-Sprache, die als CSS-Präprozessor mit Variablen, Schleifen und vielen anderen Funktionen, die Cascading Style Sheets (CSS) nicht beinhaltet, die Erstellung von CSS vereinfacht und die Pflege großer Stylesheets erleichtert. Sie wurde ursprünglich beeinflusst von der Auszeichnungssprache YAML, von Hampton Catlin entworfen und von Natalie Weizenbaum entwickelt.

Nach der Fertigstellung der initialen Version setzte Weizenbaum zusammen mit Chris Eppstein die Arbeit an Sass fort und implementierte mit SassScript eine einfache Scriptsprache zum Gebrauch innerhalb von Sass-Dateien. Neben der unter MIT-Lizenz für viele Plattformen verfügbaren kommandozeilenbasierten Compilersoftware haben sich weitere Verarbeitungsprogramme etabliert.

Neben der ursprünglichen an YAML angelehnten Sass-Syntax unterstützt Sass auch die neuere und heute weiter verbreitete SCSS-Syntax, die sich an der klassischen CSS-Schreibweise orientiert.

Merkmale

Geschachtelte Regeln

Eines der Schlüsselmerkmale sind verschachtelte Regeln (nested rules). Durch diese ist es einfach, komplizierte geschachtelte Selektoren zu lesen und zu schreiben.

#header
  background: #FFFFFF
  /* -or-  :background #FFFFFF */

  .error
    color: #FF0000

  a
    text-decoration: none
    &:hover
      text-decoration: underline

Dies wird kompiliert zu:

#header {
  background: #FFFFFF;
}
#header .error {
  color: #FF0000;
}
#header a {
  text-decoration: none
}
#header a:hover {
  text-decoration: underline
}

Geschachtelte Media Queries

Eine besondere Funktion stellt die Verschachtelung von Media Queries in Selektoren dar. So können im Quellcode Style-Deklarationen für ein und dasselbe Element am gleichen Ort verwaltet werden.

#header
  color: red
  @media (min-width: 400px)
    color: blue

Dies wird kompiliert zu:

#header {
  color: red;
}
@media (min-width: 400px){
  #header {
    color: blue;
  }
}

Variablen

Sass erlaubt die Nutzung von Variablen. Dies erleichtert es, bestimmte Werte in umfangreichen Stylesheets konsistent zu halten. Wartungsaufgaben werden durch die Definition der Variablen an zentraler Stelle erheblich vereinfacht.

$link_color: #00F

a
  color: $link_color

Wird kompiliert zu

a {
  color: #00F
}

Mixins

Mixins erlauben die wiederholte Referenzierung ganzer Code-Abschnitte. In Anlehnung an die in klassischen Programmiersprachen vorhandenen Funktionen können Mixins auch Argumente übergeben werden. Mixins können, wie normale Anweisungen auch, weitere geschachtelte Selektoren enthalten. Im folgenden Beispiel wird die Variable $farbe im Mixin dem Element als Hintergrundfarbe zugewiesen.

@mixin box($farbe)
  padding: 1rem
  border: 2px solid gray
  background: $farbe

a
  @include box(red)

Wird kompiliert zu

a {
  padding: 1rem;
  border: 2px solid gray;
  background: red;
}

SCSS-Syntax

Neben der oben beschriebenen Sass-Syntax (indented syntax) verfügt Sass über die neuere und heute weiter verbreitete SCSS-Syntax (Sassy CSS). Hier sind für die Verschachtelung der Selektoren nicht die Einrückung des Quelltextes ausschlaggebend, sondern wie in der klassischen CSS-Schreibweise die geschweiften Klammern. Auch sind am Ende der Regeln Semikola erforderlich.

Codevergleich

Sass

$meineFarbe: #3BBFCE

.navigation
  border-color: $meineFarbe
  color: darken($meineFarbe, 9%)

SCSS

$meineFarbe: #3BBFCE;

.navigation {
  border-color: $meineFarbe;
  color: darken($meineFarbe, 9%);
}

Das kompilierte CSS ist in beiden Fällen identisch. Eine automatische Umwandlung zwischen den beiden Syntax-Varianten ist ohne Probleme möglich.

SassScript

SassScript ist eine Skriptsprache, die innerhalb von Sass zur Anwendung kommt. SassScript erweitert Sass um Funktionen wie Grundrechenarten, Methoden zur Manipulation von Farbwerten, einfache Schleifenkonstrukte und Fallunterscheidungen.

Kritik

Die Nutzung einer Metasprache für CSS erfordert die Übersetzung in CSS-Code durch einen Präprozessor und damit einen weiteren Schritt im Entwicklungsprozess. Kritisiert wird das damit einhergehende erschwerte Debugging sowie das Erweitern potenzieller Fehlerquellen. Auch könne der Kaskadierungsgedanke von CSS verloren gehen, der mit der Vergabe von Klassen gegeben ist.[2]

Siehe auch

Weblinks

Einzelnachweise

  1. https://github.com/sass/dart-sass/releases/tag/1.52.3
  2. Über den (Un)Sinn von CSS Frameworks (Memento vom 13. September 2010 im Internet Archive)

Auf dieser Seite verwendete Medien