Mit Hilfe des Makros LayoutStack können Seitenelement in dynamische Spalten verteilt werden. Dies kann zum Beispiel auf Startseiten oder der Homepage sinnvoll sein oder für die Aufteilung von Listen auf mehrere Spalten.
Das Makro LayoutStack erzeugt einen maximal vierspaltigen Bereich. Wenn beim Verkleinern des Fensters die Spalten schmaler als ein angebarer Minimalwert werden, so wird das Layout in zwei Spalten umgestellt und wenn auch diese zu schmal werden wird nur noch eine Spalte erstellt.
{{LayoutStack|MinimalBreite|full|sep|Attribute}}
Es müssen immer genau vier Layout-Stack Elemente definiert werden, welche jeweils durch ein LayoutStack Makro eingeschlossen und von einander getrennt sind. Also bilden immer 5 Aufrufe des Makros einen Layout-Stack.
{{LayoutStack|120}} Element1 {{LayoutStack}} Element2 {{LayoutStack}} Element3 {{LayoutStack}} Element4 {{LayoutStack}}
Wenn genügend Platz in der Horizontalen vorhanden ist, werden die Elemente 1 bis 4 von links nach rechts nebeneinander gesetzt.
Wenn der Platz knapp wird, wird Element 2 unter Element 1 gesetzt und Element 4 unter Element 3. Wenn es noch enger wird, werden die vier Elemente untereinander gesetzt.
Diese Art der Annordnung garantiert, dass die Sortierung einer Liste, welche in vier Elemente 1 bis 4 aufgeteilt wird, beim Umordnen der Elemente immer erhalten bleibt.
{{LayoutStack|150}} * [[JSG: Linien Funktionen#MoveTo|]] * [[JSG: Linien Funktionen#LineTo|]] * [[JSG: Linien Funktionen#Line|]] {{LayoutStack}} * [[JSG: Linien Funktionen#Polygon|]] * [[JSG: Rechteck Funktionen#Rect|]] * [[JSG: Rechteck Funktionen#RectWH|]] {{LayoutStack}} * [[JSG: Kreis und Ellipsen Funktionen#Circle|]] * [[JSG: Kreis und Ellipsen Funktionen#Arc|]] * [[JSG: Kreis und Ellipsen Funktionen#ArcTo|]] {{LayoutStack}} * [[JSG: Kreis und Ellipsen Funktionen#ArcPt|]] * [[JSG: Kreis und Ellipsen Funktionen#Ellipse|]] * [[JSG: Kreis und Ellipsen Funktionen#EllipseArc|]] {{LayoutStack}}
Und so sieht's aus:
Verkleinere das Fenster und verfolge, wie die Listenelemente neu angeordnet werden. Die Style-Angabe bewirkt, dass keine vertikalen Abstände zwischen den Teillisten entstehen.
Die diversen Html-Elemente, welche das Spaltenlayout ausmachen, erhalten Attribute, über welche per Style Sheet deren Aussehen beeinflusst werden kann. Dies sind:
Die fortlaufende Nummer für die Html-ID beginnt auf jeder Seite neu von 1. Die fortlaufende Nummer für die Klasse Cell<n>beginnt bei jeder Zeile neu von 1.
Ein einfaches 4-spaltiges Layout erzeugt folgenden Html-Code:
<div id="LayoutStack4-1" class="stack4Col120px LayoutStack4-Container"> <div class="stack2Col120px LayoutStack4-Group Group1"> <div class="stack1Col120px LayoutStack4-Cell Cell1"> Element1 </div> <div class="stack1Col120px LayoutStack4-Cell Cell2"> Element2 </div> </div> <div class="stack2Col120px LayoutStack4-Group Group2"> <div class="stack1Col120px LayoutStack4-Cell Cell3"> Element3 </div> <div class="stack1Col120px LayoutStack4-Cell Cell4"> Element4 </div> </div> </div>
Hinweis: Das LayoutStack-Element hat oben und unten je nach Argumente einen Abstand zum vorherigen bzw. nachfolgenden Element definiert (Styles margin-top und margin-bottom). Will man ein LayoutStack-Element in ein Div oder eine Tabellen-Zelle ohne Abstand setzen, so kann dies über ein Stylesheet erfolgen, welches über die ID auf den betroffenen LayoutStack zugreift:
<style> #LayoutStack4-1 { margin-top: 0; margin-bottom: 0; } </style>