Bootstrap (Framework)

Bootstrap

Eine mit Bootstrap 5.0 gestaltete Webseite im Mozilla Firefox 88
Eine mit Bootstrap 5.0 gestaltete Beispielseite im Mozilla Firefox 88
Basisdaten

Entwickler Twitter
Erscheinungsjahr 19. August 2011[1]
Aktuelle Version 5.3.3[2]
(20. Februar 2024)
Aktuelle Vorabversion 5.0.0-beta1[3]
(7. Dezember 2020)
Betriebssystem Plattformunabhängig
Programmier­sprache JavaScript, Cascading Style Sheets, HTML, Sass
Kategorie Webdesign
Lizenz MIT-Lizenz[4]
deutschsprachig nein
getbootstrap.com

Bootstrap ist ein freies Frontend-CSS-Framework. Es enthält auf HTML und CSS basierende Gestaltungsvorlagen für Typografie, Formulare, Buttons, Tabellen, Grid-Systeme, Navigations- und andere Oberflächengestaltungselemente sowie zusätzliche, optionale JavaScript-Erweiterungen.

Entstehung

Bootstrap ist ursprünglich aus dem Vorhaben entstanden, die internen Analyse- und Verwaltungswerkzeuge von Twitter weiterzuentwickeln. Zu diesem Zeitpunkt wurden in dem Unternehmen unterschiedlichste Bibliotheken für die Oberflächenentwicklung eingesetzt, was zu Inkonsistenz und hohem Wartungsaufwand führte.[5] Um diesen Herausforderungen zu begegnen, wurde der Schwerpunkt des Projekts erweitert:

“[…] a super small group of developers and I got together to design and build a new internal tool and saw an opportunity to do something more. Through that process, we saw ourselves build something much more substantial than another internal tool. Months later, we ended up with an early version of Bootstrap as a way to document and share common design patterns and assets within the company.”

„[…] eine sehr kleine Gruppe von Entwicklern und ich haben uns zusammengesetzt, um ein neues internes Werkzeug zu gestalten und sahen dabei die Möglichkeit, mehr daraus zu machen. Während des Prozesses stellten wir fest, dass wir dabei waren, etwas zu erschaffen, was wesentlich weitreichender war als nur ein weiteres internes Werkzeug. Monate später hielten wir eine frühe Version von Bootstrap in den Händen, welche allgemeine Entwurfsmuster und Erkenntnisse innerhalb der Firma dokumentierte.“

Mark Otto: In seinem persönlichen Blog zur Entwicklung von Bootstrap.[6]

Dabei spielt laut Aussage von Otto die Idee, Designer und Entwickler zusammenzubringen, eine elementare Rolle bei der Entwicklung: „From whiteboarding ideas to coding rough prototypes, collaborating across disciplines is what made Bootstrap successful for internal use at Twitter.“[7], („Vom Skizzieren von Ideen bis hin zur Programmierung grober Prototypen war es die interdisziplinäre Zusammenarbeit, die Bootstrap für die interne Nutzung bei Twitter so erfolgreich gemacht hat“).

Der Name Bootstrap entlehnt sich von der Geschichte des Hieronymus Carl Friedrich von Münchhausen, auch bekannt als „Baron Münchhausen“, der unter anderem die Lügengeschichte auftischte, dass er sich an den eigenen Haaren aus einem Sumpf zöge (strap), wobei statt eines Haars ein Stiefel (boot) eingesetzt wird, was es auch als englischsprachiges Sprichwort gibt.[8] Da das Bootstrapframework die Basis ist, auf dem andere Teile der Webseite aufbauen, wird so der sachliche Zusammenhang hergestellt (vgl. Bootstrapping (Informatik)).

Den ersten Einsatz unter realen Bedingungen erfuhr Bootstrap auf Twitters erster Hackweek.[Anmerkung 1] Otto zeigte einigen Kollegen, wie sie die Entwicklung ihrer Projekte mit Hilfe des Toolkits beschleunigen können. Bei der Präsentation der Ergebnisse zeigte sich, dass Dutzende Teams auf das Framework zurückgegriffen hatten. Auf diese Weise trug Bootstrap nicht nur dazu bei, die Entwicklungszeit zu verkürzen, sondern auch ohne Hilfestellung eines dedizierten Designers ein einheitliches Look-and-Feel für die in der Hackweek entstandenen Anwendungen zu erzeugen.[7]

Im August 2011 entschloss sich Twitter, die Ergebnisse der Öffentlichkeit als Open-Source-Projekt zur Verfügung zu stellen.[5] Seitdem hat sich Bootstrap mit ≈78.900 Forks, ≈165.000 Likes und über ≈6.800 Beobachtern zu einem populären GitHub-Projekt entwickelt (Stand: September 2023).[9]

Eigenschaften

Bootstrap wurde mit Unterstützung für das damals noch relativ junge HTML5 und CSS 3 entwickelt. Da Bootstrap ab Version 3 weder Firefox 3.6 noch den Internet Explorer 7 unterstützt, wird in einem Übergangszeitraum weiterhin auch Version 2 aktualisiert. Der Gewährleistung der Browser-Kompatibilität dient das Konzept der progressiven Verbesserung.[10] Das bedeutet, dass die grundlegenden Informationen der Webseite oder -anwendung für alle Geräte und Browser zugänglich sind, erweiterte Funktionalitäten jedoch nur den Geräten und Browsern zur Verfügung stehen, die diese unterstützen. Deutlich wird dies beispielsweise bei den in CSS 3 eingeführten Eigenschaften für abgerundete Ecken, Farbverläufe und Schatten. Diese werden von Bootstrap trotz der mangelnden Unterstützung durch ältere Webbrowser intensiv eingesetzt. Dabei gewährleistet der semantische Einsatz von HTML und die Implementierung von alternativen Stildefinitionen in den Stylesheets, dass die Informationen und Funktionen der Webseite trotz der fehlenden Funktionalitäten bei älteren Browsern zur Verfügung stehen. Gleiches gilt für die mitgelieferten JavaScript-Komponenten. Diese erweitern den Funktionsumfang des Toolkits, sind jedoch keine Voraussetzung für dessen Einsatz.

Ab Version 2.0 unterstützt Bootstrap zudem die Gestaltung im Sinne des Responsive Webdesigns.[11][10] Das bedeutet, der grafische Aufbau von Webseiten erfolgt dynamisch und unter Berücksichtigung der Eigenschaften, die das verwendete Gerät (PC, Tablet, Mobiltelefon) mit sich bringt. So passen sich angeordnete Elemente automatisch der Bildschirmauflösung bzw. Fenstergröße an.

Bootstrap wird als Open-Source-Bibliothek angeboten und auf GitHub bereitgestellt. Entwickler sind aufgerufen, sich an dem Projekt zu beteiligen, und können auf der Plattform eigene Beiträge leisten.

Aufbau und Funktionsweise

Bootstrap ist modular aufgebaut und besteht im Kern aus Sass-Stylesheets, welche die einzelnen Komponenten des Frameworks enthalten. Diese Einzelkomponenten werden von einer zentralen Bootstrap-Datei zusammengeführt.[12] Durch diesen Aufbau kann der Entwickler durch Anpassung der Bootstrap-Datei selbst entscheiden, welche Komponenten in seinem Projekt verwendet werden.

Anpassungen sind in eingeschränktem Umfang über ein zentrales Konfigurationsstylesheet möglich. Darin werden unter anderem Angaben zu Schriftart und -größe, Farbe oder dem Aufbau des Grid-Layouts gesetzt.[13] Tiefgreifendere Änderungen sind möglich, indem die Sass-Deklarationen von Bootstrap überschrieben werden.

Ab der Version 2.0 ist die Konfiguration von Bootstrap auch über eine spezielle „Customize“-Option in der Dokumentation möglich. Dabei wählt der Entwickler über ein Formular die gewünschten Komponenten und passt ggf. die Werte verschiedener Optionen seinen Bedürfnissen an. Das anschließend erzeugte Paket enthält bereits das fertig kompilierte CSS-Stylesheet.[14]

Grundgerüst: Grid-System und Responsive Webdesign

Bootstrap wird standardmäßig mit einem 940 Pixel breiten, zwölfspaltigen Grid-Layout ausgeliefert. Alternativ kann der Entwickler auch ein Layout mit variabler Breite verwenden. Für beide Fälle bietet das Toolkit vier Variationen im Sinne des Responsive Webdesigns an, welche verschiedene Auflösungen und Gerätetypen bedienen: Mobiltelefone, hoch- und querformatige Tablets, sowie PCs mit geringer und hoher (Widescreen-)Auflösung. Dabei passt sich die Breite der Spalten automatisch der zur Verfügung stehenden Fensterbreite an.[15]

Über das Konfigurationsstylesheet hat der Entwickler die Möglichkeit, die Anzahl und Breite der Spalten, den Abstand zwischen den Spalten sowie die Gesamtbreite des Layouts seinen Vorstellungen entsprechend anzupassen.[13]

Mit Release 4 ist das Grid-System an das CSS-Flexbox-System[16] angepasst worden, um sich flexibler an die bestehende Fenstergröße anzupassen: Das Grundprinzip des zwölfspaltigen Rasters wurde in Bootstrap 4 beibehalten, und das responsive Raster auf fünf Viewport-Breiten verfeinert. Wurde das Raster in Bootstrap 3 im Wesentlichen noch mit der CSS-Eigenschaft float realisiert, die nie für komplexe Layouts vorgesehen war, erlaubt der CSS-Layout-Standard Flexbox die Definition und Anordnung flexibler Boxen in Bootstrap 4. Ab Version 4 werden die Browser Internet Explorer 9 und kleiner mangels Flexport-Implementierung nicht mehr unterstützt.

Grundlegendes CSS-Stylesheet

Bootstrap enthält eine Reihe von Stylesheets, welche grundlegende Stildefinitionen für alle wichtigen HTML-Komponenten enthalten. Diese gewährleisten ein browser- und systemübergreifend einheitliches, modernes Erscheinungsbild für die Textformatierung, Tabellen und Formularelemente.[17] Der Entwickler profitiert dabei von den Erfahrungen, die bei der Entwicklung und Gestaltung von Twitter gemacht wurden und kann auf praxiserprobte Gestaltungsentscheidungen und bewährte Entwurfsmuster der Frontendgestaltung zurückgreifen.[18][19] Bootstrap 4 wurde um eine breite Palette an neuen Utility-Klassen erweitert, über die sich Rahmen, Abrundungen, Farben, Abmessungen usw. bestimmen lassen.

Wiederverwendbare Komponenten

Ergänzend zu den regulären HTML-Elementen enthält Bootstrap weitere, häufig verwendete Oberflächenelemente. Hierzu gehören unter anderem Buttons mit erweiterter Funktionalität (bspw. Gruppierung von Buttons oder Buttons mit Dropdown-Möglichkeit), Navigationselemente (Navigationslisten und -leisten, horizontale und vertikale Reiter, Brotkrümelnavigation, Paginierung usw.), Labels, erweiterte typografische Möglichkeiten, Miniaturansichten, Formatierungen für Hinweismeldungen und Fortschrittsbalken.[20]

JavaScript-Plugins

Bis einschließlich Hauptversion 4 basieren die JavaScript-Komponenten von Bootstrap auf dem JavaScript-Framework jQuery. Die im Toolkit enthaltenen Plugins sind dementsprechend jQuery-Plugins. Sie bieten zusätzliche User-Interface-Elemente, wie beispielsweise Dialogfenster, Tooltips und Karussells. Außerdem erweitern sie die Funktionalität einiger vorhandener Oberflächenelemente, darunter zum Beispiel eine Autovervollständigungs-Funktion für Eingabefelder.[21]

Mit der Veröffentlichung der Alpha-Version von Bootstrap 5 wurde die Abhängigkeit von jQuery abgeschafft.[22]

Cards-Komponente

Mit Bootstrap 4 wurde die Cards-Komponente eingeführt, die die Integration von Bildern, Texten, Listen, Buttons und Navigationsleisten in Karten ermöglicht, deren Kopf- und Fußbereich optisch absetzbar sind. Mit Flexbox lassen sich mehrere Karten in gleicher Höhe nebeneinander platzieren. Mit der CSS-Eigenschaft card-columns können die Karten auf ähnliche Weise wie Inhalte der Pinterest-App organisiert werden, jedoch von oben nach unten und von links nach rechts.

Verwendung

Um Bootstrap in einer HTML-Seite zu verwenden, muss lediglich ein fertiges ZIP-Archiv von der Bootstrap-Webseite heruntergeladen werden. Dieses Archiv enthält bereits fast alle benötigten, in das eigene Projekt einzubindenden Dateien, wie eine Stylesheet-Datei mit allen Komponenten, eine JavaScript-Datei mit allen Plugins und auch eine benötigte Icon-Schriftart. Alternativ gibt es auf GitHub noch ein vollständiges, deutlich umfangreicheres ZIP-Archiv für Entwickler herunterzuladen, welches auch Beispiele für typische Webseiten zur bequemen Verwendung als Ausgangsdatei und vieles weitere enthält.

Die Dateien im ZIP-Archiv müssen in das eigene HTML-Dokument/Projekt eingebunden werden. Soll auch mit Javascript-Komponenten gearbeitet werden, so muss die Javascript-Datei zusammen mit der jQuery-Bibliothek ebenfalls im HTML-Dokument referenziert werden. Möchte man angepasste Einstellungen für Stil und Javascript-Funktionalität, besteht die Möglichkeit, fast alle Elemente von Bootstrap auf der Website selbst zu verändern und ein angepasstes Paket herunterzuladen. Schließlich kann man Bootstrap auch lokal, seinen Bedürfnissen entsprechend, vom Standard abweichend kompilieren.

Das folgende Beispiel verdeutlicht die Funktionsweise. Der HTML-Quellcode definiert eine einfache Template. Die Seite besteht aus regulären, semantisch verwendeten HTML5-Elementen sowie einigen zusätzlichen CSS-Klassenangaben entsprechend der Bootstrap-Dokumentation.[Anmerkung 2]

<!DOCTYPE html>
<html lang="en">
<head>
  <title>Bootstrap 5 Example</title>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  
  <!-- Einbinden des Bootstrap-Stylesheets -->
  <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css" rel="stylesheet">
  
  <!-- optional: Einbinden der Bootstrap.bundle.min.js -->
  <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/js/bootstrap.bundle.min.js"></script>
</head>
<body>

<div class="container-fluid p-5 bg-primary text-white text-center">
  <h1>My First Bootstrap Page</h1>
  <p>Resize this responsive page to see the effect!</p> 
</div>
  
<div class="container mt-5">
  <div class="row">
    <div class="col-sm-4">
      <h3>Column 1</h3>
      <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit...</p>
      <p>Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris...</p>
    </div>
    <div class="col-sm-4">
      <h3>Column 2</h3>
      <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit...</p>
      <p>Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris...</p>
    </div>
    <div class="col-sm-4">
      <h3>Column 3</h3>        
      <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit...</p>
      <p>Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris...</p>
    </div>
  </div>
</div>

</body>
</html>

Siehe auch

Anmerkungen

  1. Eine Beschreibung des Konzeptes der Hackweek im offiziellen Twitter-Blog
  2. Die JavaScript-Komponenten werden in diesem Beispiel nicht verwendet und nur der Vollständigkeit halber referenziert.
Commons: Bootstrap (Framework) – Sammlung von Bildern

Einzelnachweise

  1. twitter.com.
  2. Release 5.3.3. 20. Februar 2024 (abgerufen am 20. Februar 2024).
  3. Relase 5.0.0-beta1. 7. Dezember 2020 (abgerufen am 12. Dezember 2020).
  4. getbootstrap.com.
  5. a b Mark Otto: Bootstrap from Twitter. 19. August 2011, abgerufen am 17. August 2015.
  6. Mark Otto: Bootstrap in A List Apart #342. 17. Januar 2012, abgerufen am 25. Februar 2012.
  7. a b Mark Otto: Building Twitter Bootstrap. 17. Januar 2012, abgerufen am 25. Februar 2012.
  8. pull oneself up by one's bootstraps (englischsprachiges Wiktionary)
  9. Github.com/twbs/bootstrap. Bootstrap, abgerufen am 17. September 2023 (englisch).
  10. a b Bootstrap, from Twitter. Archiviert vom Original (nicht mehr online verfügbar) am 2. August 2012; abgerufen am 25. Februar 2012 (Offizielle Projektseite auf GitHub).  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/twitter.github.com
  11. Mark Otto: Say hello to Bootstrap 2.0. 31. Januar 2012, archiviert vom Original (nicht mehr online verfügbar) am 3. Februar 2012; abgerufen am 25. Februar 2012 (englisch).
  12. less/bootstrap.less at master from twitter/bootstrap. Abgerufen am 12. September 2014 (Das bootstrap.less-Stylesheet im Bootstrap-Repository auf GitHub).
  13. a b less/variables.less at master from twitter/bootstrap. Abgerufen am 25. Februar 2012 (Das variables.less-Stylesheet im Bootstrap-Repository auf GitHub).
  14. Customize and Download. Archiviert vom Original (nicht mehr online verfügbar) am 24. Februar 2012; abgerufen am 25. Februar 2012 (Die „Customize“-Option in der Bootstrap-Dokumentation).  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/twitter.github.com
  15. Scaffolding. Archiviert vom Original (nicht mehr online verfügbar) am 25. Februar 2012; abgerufen am 25. Februar 2012 (Beschreibung des Grid-Systems in der Bootstrap-Dokumentation).  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/twitter.github.com
  16. Flexbox. Abgerufen am 24. März 2017 (Beschreibung des Flexbox-Systems im Mozilla Developer Network).
  17. Base CSS. Archiviert vom Original (nicht mehr online verfügbar) am 24. Februar 2012; abgerufen am 25. Februar 2012 (Beschreibung des Base-CSS-Stylings in der Bootstrap-Dokumentation).  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/twitter.github.com
  18. Alexander Neumann: Twitter gibt HTML5-Framework Bootstrap 2.0 frei. In: heise Developer. 2. Februar 2012, abgerufen am 25. Februar 2012.
  19. Dieter Petereit: Bootstrap: CSS- und HTML5-basiertes WebApp-Toolkit von Twitter. In: t3n. 23. August 2011, abgerufen am 25. Februar 2012.
  20. Components. Archiviert vom Original (nicht mehr online verfügbar) am 24. Februar 2012; abgerufen am 25. Februar 2012 (Beschreibung der zusätzlichen Komponenten in der Bootstrap-Dokumentation).  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/twitter.github.com
  21. Javascript for Bootstrap. Abgerufen am 14. Januar 2013 (Beschreibung der JavaScript-Komponenten in der Bootstrap-Dokumentation).
  22. jQuery and JavaScript. Abgerufen am 16. Juni 2020 (Bootstrap verwendet jQuery nicht mehr).

 

Prefix: a b c d e f g h i j k l m n o p q r s t u v w x y z 0 1 2 3 4 5 6 7 8 9

Portal di Ensiklopedia Dunia