Skip to main content
Simple components

Menus and menubars

An HTML menu is usually an unordered list or ordered list of links, but it can be used on other elements too.

A simple menu

There are numerous utility classes in Codebase that can be used to lake a menu look distinctive.

If you are using an ol or ul then the following example is a good place to start:

  1. On the ol or ul use list-style-type-none to remove the numbers or bullet points.
  2. Remove the ol or ul side padding, so that the list items do not appear indented.
  3. You may also need to remove the bottom margin of the ol or ul.
  4. Make each link in the menu to be styled as a block-level element, and add some padding – this increases the link area for large fingers on touch screen devices.
  5. You may want menu links not to be styled the same as traditional colored links within your main content (prose text).

An unordered list of links:

The same unordered list, but using the <nav> tag for improved accessability, and styled as a menu:

<nav class="list-style-type-none mb-2 p-0 flex flex-column gap-2 links-underline-hover-only">
<li><a class="block t-gray-600 hover:t-black" href="">...</a></li>
<li><a class="block t-gray-600 hover:t-black" href="">...</a></li>
<li><a class="block t-gray-600 hover:t-black" href="">...</a></li>
<li><a class="block t-gray-600 hover:t-black" href="">...</a></li>
<li><a class="block t-gray-600 hover:t-black" href="">...</a></li>
</nav>

More menu examples

Following the code example below are three examples of menus with sub menus – all styled with Codebase utilities applied to the same example base:

<nav>
<li><a href="">Link 1</a></li>
<li><a href="">Link 2</a></li>
<li><a href="">Link 3</a>
<ul>
<li><a href="">Link 3.1</a></li>
<li><a href="">Link 3.2</a></li>
<li><a href="">Link 3.3</a></li>
</ul>
</li>
<li><a href="">Link 4</a></li>
<li><a href="">Link 5</a></li>
</nav>

You can look at the source code to see how the following examples have been decorated with utility classes.

You can use flexbox layout utilities on menus for making menubars.

Simple menubar

In the example below, sm:flex has been used, so that the menu stays as a columnar menu below the sm breakpoint width (i.e. below 768px, default), and then it becomes a menubar from that width up.

With some other simple components inside for proof of concept.

<nav class="list-style-type-none mb-0 pl-0 sm:flex flex-middle flex-wrap">
<li><a class="block p-cell t-nowrap" href="#/">Link 1</a></li>
...
<li><a class="btn btn-primary btn-sm w-100% flex-start" href="#/">Link 5</a></li>
...
</nav>

If you have items of different heights (e.g. badges, buttons, search form) and you want them to line up at the vertical middle, add flex-middle as in this example. If your menubar is overloaded with items, ensure that it behaves OK on smaller screens by adding flex-wrap or overflow-x – or adjust the breakpoint (e.g. maybe you need to use md:flex instead of sm:flex).

Example menubar with an AplineJS powered dropdown (sub menu):

<div class="mb-2 xs:flex flex-middle flex-space-between bg-purple-600">
<div>
<a class="block p-2 t-lg t-bold t-white hover:t-white t-no-underline" href="">Brand</a>
</div>
<nav class="list-style-type-none mb-0 pl-0 xs:flex flex-middle flex-end links-no-underline">
<li><a class="block p-cell t-white hover:t-white hover:bg-purple-700" href="">Home</a></li>
<li>
<div
x-data="{
open: false,
toggle() {
if (this.open) {
return this.close()
}
this.open = true
},
close(focusAfter) {
this.open = false
focusAfter && focusAfter.focus()
}
}"

@keydown.escape.prevent.stop="close($refs.button)"
@focusin.window="! $refs.panel.contains($event.target) && close()"
x-id="['dropdown-panel']"
class="relative"
>

<button
x-ref="button"
@click="toggle()"
:aria-expanded="open"
:aria-controls="$id('dropdown-panel')"
type="button"
class="b-0 unrounded t-normal t-white hover:t-white hover:bg-purple-700"
:class="open && 'bg-purple-700 hover:bg-purple-700'"
>

<span>About</span>
<!-- Icon caret down -->
</button>
<div
x-cloak
x-ref="panel"
x-show="open"
@click.outside="close($refs.button)"
:id="$id('dropdown-panel')"
class="absolute xs:right z-index-1 b-thin rounded rounded-sm bs-2 bg-white"
style="min-width: 10rem"
>

<ul class="list-style-type-none mb-0 px-0 py-1 links-underline-hover-only">
<li><a class="block p-cell" href="">Company info</a></li>
<li><a class="block p-cell" href="">Management</a></li>
<li><a class="block p-cell" href="">Careers</a></li>
</ul>
</div>
</div>
</li>
<li><a class="block p-cell t-white hover:t-white hover:bg-purple-700" href="">Contact</a></li>
</nav>
</div>