Reset-Stylesheet
Ein Reset-Stylesheet (oder auch: CSS Reset) ist eine Sammlung von Stylesheet-Definitionen, die Formatierungen für HTML-Elemente vereinheitlichen oder zurücksetzen.
Problematik
Jeder Browser hat unterschiedliche Standardeinstellungen für verschiedene HTML-Elemente. So sind etwa die Farbe für Linktexte und Abstandsdefinitionen für bestimmte Elemente von vielen Browsern standardmäßig unterschiedlich definiert. Diese Basisangaben unterscheiden sich mitunter stark von Browser zu Browser, teilweise sogar innerhalb verschiedener Versionen eines Browsers.[1] Diese Standardstile können insbesondere in Kombination mit vom Autor definierten Vorgaben unvorhergesehene Auswirkungen auf das Erscheinungsbild der Website zur Folge haben.
Mit der Hilfe eines Stylesheet-Resets können diese Basisangaben der Browser zurückgesetzt werden. Die dann vom Entwickler eingesetzten Stilangaben werden im Idealfall konsistent von allen Browsern interpretiert.
Das Zurücksetzen der Stylesheet-Definitionen
Etwa 2004 wurden erste sogenannte Stylesheet-Resets veröffentlicht,[2] welche sich auf das Zurücksetzen der Abstandsangaben beschränkten:
* {
padding:0;
margin:0;
}
Dieses Verfahren wurde von verschiedenen Entwicklern nach und nach verfeinert, so dass nur ausgewählte und sinnvolle Elemente auf grundlegende Angaben zurückgesetzt wurden.
Bekannte Stylesheet-Resets
Nachteile
- Viele CSS-Resets entfernen jede Formatierung eines HTML-Elements. So hat beispielsweise selbst das
strong
-Element, welches hervorgehobenen bzw. fettgedruckten Text auszeichnet, in Form und Farbe oft keinen Unterschied mehr zum Rest des Textes. Der Entwickler muss sich also um jeden designrelevanten Parameter seines HTML-Codes kümmern. - Je nach Umfang eines Resets entsteht eine höhere Ladezeit, da die bestehende Stylesheet-Datei entweder erweitert oder die Ressource zusätzlich geladen werden muss.
- Die Unterschiede zwischen einzelne Browser sind nur geringfügig und meistens nicht relevant für den Gesamteindruck. Eine Website soll flexibel dargestellt werden, wobei es nicht auf den Abstand einzelner Pixel ankommt. Es entsteht ein Mehraufwand für den Entwickler minimale Unterschiede zwischen Browsern zu beheben, wenn er einen CSS-Reset nutzt.[7]
Weiterentwicklung
Um die Nachteile zu beheben, gibt es verschiedene Weiterentwicklungen des klassischen CSS-Resets:
Ein Ansatz ist CSS-Normalize. Dabei werden alle Eigenschaften einheitlich festgelegt, statt sie zurückzusetzen. Das Ziel ist es, dass alle Browser sich gleich verhalten, aber sinnvolle Voreinstellungen wie Listenpunkte oder fettgedruckter Text bei einem strong
-Element beibehalten wird. Außerdem werden bekannte Bugs verschiedener Darstellungen von Browsern behoben.[8][9]
Als Weiterentwicklung von CSS-Normalize ist CSS-Sanitize entstanden, um mehr den Anforderungen aktueller Projekte zu entsprechen. Dafür wird nicht auf die Kompatibilität veralteter Browser geachtet und die Regeln wurden verbessert. Viele Regeln sind subjektiv, allerdings gut begründet in der Stylesheet-Datei.[10]
Am beliebtesten ist seit Februar 2020 CSS-Sanitize, was an der Anzahl der Downloads auf Npm deutlich wird.[11]
Abgrenzung zum CSS-Framework
Ein CSS-Reset ist von einem CSS-Framework abzugrenzen. Ein Reset-Stylesheet hat lediglich die Aufgabe, Basisformatierungen zurückzusetzen. Im Gegensatz dazu versucht ein CSS-Framework, beispielsweise mithilfe vorgefertigter Stil-Definitionen für oft benötigte Elemente der Benutzeroberfläche oder einem Rastersystem den Entwicklungsprozess einer Website zu beschleunigen. Oftmals ist ein CSS-Reset jedoch Teil des CSS-Frameworks.
Weblinks
- Übersicht über verschiedene CSS-Resets (englisch)
- Reset CSS von Eric Meyer (englisch)
- Projektseite von CSS-Normalize der Entwickler Nicolas Gallagher und Jonathan Neal (englisch)
- Projektseite von CSS-Sanitize (englisch)
Einzelnachweise
- Browserkompatibilität: Probleme mit der Darstellung von Webseiten in verschiedenen Browsern | Tipps zur Web-Usability. Abgerufen am 12. Juni 2020.
- William Craig President of WebFX, Inc.: The History of CSS Resets. In: WebFX Blog. 2. Dezember 2010, abgerufen am 12. Juni 2020 (englisch).
- CSS Reset - YUI Library. Abgerufen am 12. Juni 2020.
- Poll Results: What CSS Reset Do You Use? 6. März 2008, abgerufen am 12. Juni 2020 (englisch).
- CSS-Reset: Rücksetzen der Browservorgaben. Abgerufen am 12. Juni 2020.
- CSS Tools: Reset CSS. Abgerufen am 12. Juni 2020 (englisch).
- von Ellen: Tipps und Tricks zum CSS-Reset | Elmastudio. In: Elmastudio - Creative & Minimal WordPress Themes. 23. Februar 2011, abgerufen am 12. Juni 2020 (deutsch).
- Normalize.css - Was ist das? - Infos zur CSS Normalisierung. In: Webdesign Hannover - Saskia Lund. 13. Juni 2015, abgerufen am 12. Juni 2020 (deutsch).
- About normalize.css – Nicolas Gallagher. Abgerufen am 12. Juni 2020 (englisch).
- CSS-Basis durch Reset oder Normalisierung – normalize CSS | Adfreak. Abgerufen am 12. Juni 2020 (deutsch).
- NPM Trends: Compare NPM package downloads. Abgerufen am 12. Juni 2020 (englisch).