2016-09-11 11:00:49 +00:00
---
2017-07-29 12:02:00 +00:00
title: Responsiveness
2016-09-11 11:00:49 +00:00
layout: documentation
doc-tab: overview
doc-subtab: responsiveness
2017-10-17 09:28:59 +00:00
variables_keys:
- gap
- tablet
- desktop
- widescreen
- fullhd
2016-09-11 11:00:49 +00:00
---
2018-04-08 19:11:48 +00:00
{% capture scss_code %}
// Disable the widescreen breakpoint
$widescreen-enabled: false
// Disable the fullhd breakpoint
$fullhd-enabled: false
{% endcapture %}
2018-03-26 13:46:39 +00:00
{% include subnav/subnav-overview.html %}
2016-09-11 11:00:49 +00:00
< section class = "section" >
< div class = "container" >
< h1 class = "title" > Responsiveness< / h1 >
< h2 class = "subtitle" > Bulma is a < strong > mobile-first< / strong > framework< / h2 >
2017-08-30 19:44:39 +00:00
{% include anchor.html name="Vertical by default" %}
2016-09-11 11:00:49 +00:00
2017-03-14 21:19:06 +00:00
< div class = "content" >
< p >
2017-05-01 09:48:52 +00:00
Every element in Bulma is < strong > mobile-first< / strong > and optimizes for < strong > vertical reading< / strong > , so by default on mobile:
2017-03-14 21:19:06 +00:00
< / p >
< ul >
< li > < code > columns< / code > are stacked vertically< / li >
< li > the < code > level< / code > component will show its children stacked vertically< / li >
< li > the < code > nav< / code > menu will be hidden< / li >
< / ul >
2017-10-02 18:24:29 +00:00
< p > For example, you can enforce the < strong > horizontal< / strong > layout for both < code > columns< / code > or < code > nav< / code > by appending the < code > is-mobile< / code > modifier.< / p >
2017-03-14 21:19:06 +00:00
< / div >
2017-08-30 19:44:39 +00:00
{% include anchor.html name="Breakpoints" %}
2017-12-06 23:48:35 +00:00
2018-03-26 13:46:39 +00:00
{% assign variables_file_url = "/blob/master/sass/utilities/initial-variables.sass#L46,L57" | prepend: site.data.meta.github %}
{% assign mixins_file_url = "/blob/master/sass/utilities/mixins.sass#L182,L226" | prepend: site.data.meta.github %}
2017-03-14 21:19:06 +00:00
2016-09-11 11:00:49 +00:00
< div class = "content" >
2017-10-12 14:40:04 +00:00
< p > Bulma has < a href = "{{ variables_file_url }}" target = "_blank" > 5 breakpoints< / a > :< / p >
2016-09-11 11:00:49 +00:00
< ul >
2017-10-12 14:40:04 +00:00
{% for breakpoint_hash in site.data.breakpoints %}
{% assign breakpoint = breakpoint_hash[1] %}
2018-04-08 19:11:48 +00:00
< li > < code > {{ breakpoint.id }}< / code > : {% if breakpoint.id == 'mobile' %}up to < code > {{ breakpoint.to }}px< / code > {% else %}from < code > {{ breakpoint.from }}px< / code > {% endif %}< / li >
2017-10-12 14:40:04 +00:00
{% endfor %}
2016-09-11 11:00:49 +00:00
< / ul >
2017-12-06 23:48:35 +00:00
2017-10-12 14:40:04 +00:00
< p > Bulma uses < a href = "{{ mixins_file_url }}" target = "_blank" > 9 responsive mixins< / a > :< / p >
2016-09-11 11:00:49 +00:00
< ul >
2017-10-12 14:40:04 +00:00
{% for breakpoint_hash in site.data.breakpoints %}
{% assign breakpoint = breakpoint_hash[1] %}
{% case breakpoint.id %}
{% when 'mobile' %}
< li >
< code > ={{ breakpoint.id }}< / code > < br >
until < code > {{ breakpoint.to }}px< / code >
< / li >
{% when 'fullhd' %}
< li >
< code > ={{ breakpoint.id }}< / code > < br >
from < code > {{ breakpoint.from }}px< / code >
< / li >
{% else %}
< li >
< code > ={{ breakpoint.id }}< / code > < br >
from < code > {{ breakpoint.from }}px< / code >
< / li >
< li >
< code > ={{ breakpoint.id }}-only< / code > < br >
from < code > {{ breakpoint.from }}px< / code > and until < code > {{ breakpoint.to }}px< / code >
< / li >
{% if breakpoint.id == 'tablet' %}
< li >
< code > =touch< / code > < br >
until < code > {{ breakpoint.to }}px< / code >
< / li >
{% endif %}
{% endcase %}
{% endfor %}
2016-09-11 11:00:49 +00:00
< / ul >
< / div >
2017-03-14 21:19:06 +00:00
< table class = "table is-bordered" >
2016-09-11 11:00:49 +00:00
< thead >
< tr >
2017-10-12 14:40:04 +00:00
{% for breakpoint_hash in site.data.breakpoints %}
{% assign breakpoint = breakpoint_hash[1] %}
< th style = "width: 20%;" >
{{ breakpoint.name }}< br >
{% if breakpoint.id == 'mobile' %}
Up to < code > {{ breakpoint.to }}px< / code >
{% elsif breakpoint.id == 'fullhd' %}
< code > {{ breakpoint.from }}px< / code > and above
{% else %}
Between < code > {{ breakpoint.from }}px< / code > and < code > {{ breakpoint.to }}px< / code >
{% endif %}
< / th >
{% endfor %}
2016-09-11 11:00:49 +00:00
< / tr >
< / thead >
< tbody >
< tr >
2017-03-14 21:19:06 +00:00
< td >
2016-09-11 11:00:49 +00:00
< p class = "notification is-success" > mobile< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td colspan = "4" >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
< / tr >
< tr >
2017-03-14 21:19:06 +00:00
< td >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td colspan = "4" >
2016-09-11 11:00:49 +00:00
< p class = "notification is-success" > tablet< / p >
< / td >
< / tr >
< tr >
2017-03-14 21:19:06 +00:00
< td colspan = "2" >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td colspan = "3" >
2016-09-11 11:00:49 +00:00
< p class = "notification is-success" > desktop< / p >
< / td >
< / tr >
< tr >
2017-03-14 21:19:06 +00:00
< td colspan = "3" >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td colspan = "2" >
2016-09-11 11:00:49 +00:00
< p class = "notification is-success" > widescreen< / p >
< / td >
< / tr >
< tr >
2017-03-14 21:19:06 +00:00
< td colspan = "4" >
< p class = "notification" > -< / p >
< / td >
< td >
< p class = "notification is-success" > fullhd< / p >
< / td >
< / tr >
< tr >
< td >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td >
2016-09-11 11:00:49 +00:00
< p class = "notification is-success" > tablet-only< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td colspan = "3" >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
< / tr >
< tr >
2017-03-14 21:19:06 +00:00
< td colspan = "2" >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td >
2016-09-11 11:00:49 +00:00
< p class = "notification is-success" > desktop-only< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td colspan = "2" >
< p class = "notification" > -< / p >
< / td >
< / tr >
< tr >
< td colspan = "3" >
< p class = "notification" > -< / p >
< / td >
< td >
< p class = "notification is-success" > widescreen-only< / p >
< / td >
< td >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
< / tr >
< tr >
2017-03-14 21:19:06 +00:00
< td colspan = "2" >
2016-09-11 11:00:49 +00:00
< p class = "notification is-success" > touch< / p >
< / td >
2017-03-14 21:19:06 +00:00
< td colspan = "3" >
2016-09-11 11:00:49 +00:00
< p class = "notification" > -< / p >
< / td >
< / tr >
2018-04-08 19:11:48 +00:00
< tr >
< td colspan = "3" >
< p class = "notification is-success" > until-widescreen< / p >
< / td >
< td colspan = "2" >
< p class = "notification" > -< / p >
< / td >
< / tr >
< tr >
< td colspan = "4" >
< p class = "notification is-success" > until-fullhd< / p >
< / td >
< td colspan = "1" >
< p class = "notification" > -< / p >
< / td >
< / tr >
2016-09-11 11:00:49 +00:00
< / tbody >
< / table >
2017-12-06 23:48:35 +00:00
2018-04-08 19:11:48 +00:00
{% include anchor.html name="Disabling breakpoints" %}
{% include elements/new-tag.html version="0.6.3" %}
< div class = "content" >
< p >
By default, the < code > $widecreen< / code > and < code > $fullhd< / code > breakpoints are < strong > enabled< / strong > . You can disable them by setting the corresponding Sass boolean to < code > false< / code > :
< / p >
< / div >
< div class = "highlight-full" >
{% highlight sass %}{{ scss_code }}{% endhighlight %}
< / div >
2017-10-17 09:28:59 +00:00
{% include anchor.html name="Variables" %}
< div class = "content" >
< p >
You can use < a href = "{{ variables_file_url }}" target = "_blank" > these variables< / a > to < strong > customize< / strong > the responsive breakpoints. Simply set one or multiple of these variables < em > before< / em > importing Bulma. < a href = "{{ site.url }}/documentation/overview/customize/" > Learn how< / a > .
< / p >
< / div >
< table class = "table is-bordered" >
< thead >
< tr >
< th > Name< / th >
< th > Default value< / th >
< / tr >
< / thead >
< tfoot >
< tr >
< th > Name< / th >
< th > Default value< / th >
< / tr >
< / tfoot >
< tbody >
{% for key in page.variables_keys %}
{% assign variable = site.data.variables.utilities.initial-variables.vars[key] %}
< tr >
< td >
< code > {{ variable.name }}< / code >
< / td >
< td >
< code > {{ variable.value }}< / code >
< / td >
< / tr >
{% endfor %}
< / tbody >
< / table >
2017-12-06 23:48:35 +00:00
2016-09-11 11:00:49 +00:00
< / div >
< / section >