Stack (<e-stack>)
The e-stack component arranges its direct children vertically, applying a consistent space (margin) between them. It utilizes Flexbox with flex-direction: column.
Basic Usage
Vertical Stack (Default):
<e-stack>
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</e-stack>
With Custom Space:
<e-stack space="2rem">
<div>Item 1</div>
<div>Item 2</div>
<div>Item 3</div>
</e-stack>
With Split:
This example pushes Item 3 and subsequent items down by applying margin-block-end: auto to Item 2.
<e-stack split-after="2">
<div>Header</div>
<div>Main Content</div>
<div>Footer</div>
</e-stack>
Examples
Default Stack:
Item 1
Item 2
Item 3
Custom Space: space="0.5rem"
Item 1
Item 2
Item 3
Split After: split-after="2" space="0.5rem"
Item 1
Item 2 (margin-bottom: auto applied here)
Item 3 (Pushed down)
Properties
space<string>(Default:'1.5rem')- Vertical space between items. Maps to
--stack-space. Attribute:space.
- Vertical space between items. Maps to
split-after<number | null>(Default:null)- 1-based index after which to add
margin-block-end: auto, pushing subsequent items down. Attribute:split-after.
- 1-based index after which to add
tag<string>(Default:undefined)- Provides a semantic hint (e.g., ‘ul’). Does not change the rendered tag. Useful for CSS selectors (
e-stack[tag="..."]). Attribute:tag.
- Provides a semantic hint (e.g., ‘ul’). Does not change the rendered tag. Useful for CSS selectors (