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">
<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">
Search
<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>
.