Skip to main content
Classless basics

Form elements

In Codebase, many form elements have a width of 100%, for ease of styling.

If you want to make an input field an inline element, add the layout block utility class inline-block.

Single line input fields

Text

<label for="text-example">Text:</label>
<input id="text-example" name="examplename" placeholder="Example text input field" type="text">

Email

<label for="email-example">Email:</label>
<input id="email-example" name="examplename" placeholder="Example email input field" type="email">

Telephone number

<label for="tel-example">Tel:</label>
<input id="tel-example" name="examplename" placeholder="Example phone number input field" type="tel">

Password

<label for="password-example">Password:</label>
<input id="password-example" name="examplename" placeholder="Example password input field" type="password">

File upload

<label for="upload-example">File upload:</label>
<input id="upload-example" type="file" id="upload-1" name="examplename" accept="image/png, image/jpeg">

<label for="search-example">Search:</label>
<input id="search-example" name="examplename" placeholder="Example search input field" type="search">

Numeric inputs

These fields are not full-width, but whatever the visitor’s browser sets.

Number (picker)

<label for="number-example">Number:</label>
<input type="number" id="quantity" name="example" min="0" inputmode="numeric" pattern="\d*">

Date and time

<label for="date-example">Date:</label>
<input id="date-example" name="examplename" type="date">

<label for="month-example">Month (and year):</label>
<input id="month-example" name="examplename" type="month">

<label for="time-example">Time:</label>
<input id="time-example" name="examplename" type="time">

Color picker

Textareas (multi line)

<label for="textarea-example">Textarea:</label>
<textarea id="textarea-example" name="examplename" type="textarea" placeholder="Example textarea" rows="4"></textarea>

Selects

Single selects

<label for="single-select-example">Single select:</label>
<select id="single-select-example" name="examplename">
<option value="first">First option </option>
<option value="second">Second option </option>
<option value="third">Third option</option>
</select>

Multi selects

<label for="multi-select-example">Multi-select:</label>
<select id="multi-select-example" name="examplename" multiple size="3">
<option value="first">First option </option>
<option value="second">Second option </option>
<option value="third">Third option</option>
</select>

Radio boxes and checkboxes

Radio



<input id="radio-1" name="examplename" checked="checked" type="radio">
<label for="radio-1">Radio 1</label><br>
<input id="radio-2" name="examplename" type="radio">
<label for="radio-2">Radio 2</label><br>
<input id="radio-3" name="examplename" type="radio">
<label for="radio-3">Radio 3</label>

Checkbox



<input id="checkbox-1" name="examplename" checked="checked" type="checkbox">
<label for="checkbox-1">Checkbox 1 </label><br>
<input id="checkbox-2" name="examplename" type="checkbox">
<label for="checkbox-2">Checkbox 2</label><br>
<input id="checkbox-3" name="examplename" type="checkbox">
<label for="checkbox-3">Checkbox 3</label>

Buttons

This is what a Codebase default (classless) button looks like:

– button, i.e. <button>

<button type="button">Button</button>

Note: If you use a <button> outside of a <form> (e.g. as a control for a navigation dropdown), it will have no :focus incicator ring (the ring wil show only for :focus-visible). But if you use a <button> as part of a form, it will get a :focus ring.

<button type="button">Button</button>

<!-- A button in a form -->
<form>
...
<button type="Submit">Submit</button>
</form>

<input> buttons always get a :focus ring.

<input value="Click me" type="button">
<input value="Submit" type="submit">
<input value="Reset" type="reset">

See also the UI button component.

Fieldsets and legends

You can wrap a number of related inputs and buttons together in a <fieldset> and label it with a <legend>.

Subscribe to our email