--- title: Block layout: documentation doc-tab: elements doc-subtab: block breadcrumb: - home - documentation - elements - elements-block meta: colors: false sizes: false variables: true --- {% capture block_example %}
This text is within a block.
This text is within a second block. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean efficitur sit amet massa fringilla egestas. Nullam condimentum luctus turpis.
This text is within a third block. This block has no margin at the bottom.
{% endcapture %} {% capture no_block_example %}
This text is within a block.
This text is within a longer second block. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean efficitur sit amet massa fringilla egestas. Nullam condimentum luctus turpis.
This text is within a third block. This block has no margin at the bottom.
{% endcapture %} {% capture block_css %} .block:not(:last-child) { margin-bottom: 1.5rem; } {% endcapture %}

The block element is a simple spacer tool. It allows sibling HTML elements to have a consistent margin between them:

{% include elements/snippet.html content=block_example %}

As you can see, the first two blocks have a margin-bottom applied, but not the third one.. That is because Bulma applies a space on all blocks, except the last one. This means you can use as many blocks as you want, the spacing will only appear between them.

Without using block, the HTML elements would have no space between them:

{% include elements/snippet.html content=no_block_example %} {% include elements/anchor.html name="One line of CSS" %}

As you can see, the CSS of the block is very simple: it applies a margin-bottom on all siblings, except the last one.

{% highlight css %}{{ block_css }}{% endhighlight %}

This prevents the last sibling to add unnecessary space at the bottom.

{% include elements/anchor.html name="Already used everywhere in Bulma" %}

As a matter of fact, you're already using the block without knowing it. The block CSS properties are shared across several Bulma elements and components:

This is thanks to the @extend %block Sass placeholder feature.

As a result, no matter which Bulma elements and components you are using, and no matter their order, they will have a consistent space between them.

{% include elements/variables.html type='element' %}