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:
- On the
ol
orul
uselist-style-type-none
to remove the numbers or bullet points. - Remove the
ol
orul
side padding, so that the list items do not appear indented. - You may also need to remove the bottom margin of the
ol
orul
. - 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.
- 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.
Menubars
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
).
Menubar with AlpineJS dropdown
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>