Navbar
Navigation menus are complexe, but the navbar component can make it simply to add an headerwith a brand logo, navigation links and text.
info
Of course, this component is lighter and offer less possibilities than others CSS framework, but it's desired to keep it simple. And generally, if you want specific layouts, different responsive behavior, or anything else, you may create your own navigation component, and make it as accessible as possible.
<nav class="c-navbar" role="navigation" aria-label="Main navigation">
<input class="c-navbar__control" id="c-navbar-menu-example-1" type="checkbox">
<label class="c-navbar__burger" for="c-navbar-menu-example-1">
<svg viewBox="0 0 100 100" width="48">
<path d="m 70,33 h -40 c 0,0 -8.5,-0.149796 -8.5,8.5 0,8.649796 8.5,8.5 8.5,8.5 h 20 v -20"></path>
<path d="m 70,50 h -40"></path>
<path d="m 30,67 h 40 c 0,0 8.5,0.149796 8.5,-8.5 0,-8.649796 -8.5,-8.5 -8.5,-8.5 h -20 v 20"></path>
</svg>
</label><a class="c-navbar__logo" href="#"><img src="logo.svg" alt="Glsass logo" height="36"></a>
<div class="c-navbar__panel">
<ul class="c-navbar__nav">
<li><a class="c-navbar__link" href="#">Home</a></li>
<li><a class="c-navbar__link" href="#">Docs</a></li>
<li><a class="c-navbar__link" href="#">Login</a></li>
</ul>
</div>
</nav>
danger
Since the component use the "checkbox hack" to manage the open/close state on
mobile, be careful about the id/for
attributes for the input
and label
element.
You can also use utilities classes to create new behavior and layouts. Resize your window to test the mobile version
<nav class="c-navbar" role="navigation" aria-label="Main navigation">
<input class="c-navbar__control" id="c-navbar-menu-example-2" type="checkbox">
<label class="c-navbar__burger" for="c-navbar-menu-example-2">
<svg viewBox="0 0 100 100" width="48">
<path d="m 70,33 h -40 c 0,0 -8.5,-0.149796 -8.5,8.5 0,8.649796 8.5,8.5 8.5,8.5 h 20 v -20"></path>
<path d="m 70,50 h -40"></path>
<path d="m 30,67 h 40 c 0,0 8.5,0.149796 8.5,-8.5 0,-8.649796 -8.5,-8.5 -8.5,-8.5 h -20 v 20"></path>
</svg>
</label><a class="c-navbar__logo" href="#"><img src="logo.svg" alt="Glsass logo" height="36"></a>
<div class="c-navbar__panel">
<ul class="c-navbar__nav u-fd-r u-fw-w u-no-gutters">
<li class="o-col u-4 u-auto@md"><a class="c-navbar__link" href="#">Home</a></li>
<li class="o-col u-4 u-auto@md"><a class="c-navbar__link" href="#">Docs</a></li>
<li class="o-col u-4 u-auto@md"><a class="c-navbar__link" href="#">Login</a></li>
</ul>
<hr class="u-c-dark u-d-n@md">
<ul class="c-navbar__nav u-fd-r u-fw-w u-no-gutters u-ml-auto@md">
<li class="o-col u-auto"><a class="c-navbar__link" href="#">Home</a></li>
<li class="o-col u-auto"><a class="c-navbar__link" href="#">Docs</a></li>
<li class="o-col u-auto"><a class="c-navbar__link" href="#">Login</a></li>
</ul>
</div>
</nav>
note
To constrain the max-width or the navbar, you can add a div as the first child
of the .c-navbar
element with the .c-navbar__layout
class.
Then, also
add the .o-layout
object to the new container element.