Form
Easily create nicely looking forms with different styles and layouts.
Usage
To apply this component, add the .uk-form
class to a form element. All form control elements are placed side by side within the next row.
Example
NOTE In this example we used a button from the Button component. To add a top margin to form elements, when they stack on smaller viewports, just add the data-uk-margin
attribute from the Utility component to the parent element.
Markup
<form class="uk-form">
<fieldset data-uk-margin>
<legend>...</legend>
<input type="text" placeholder="">
<input type="password" placeholder="">
<select>
<option>...</option>
<option>...</option>
</select>
<button class="uk-button">...</button>
<label><input type="checkbox"> ...</label>
</fieldset>
</form>
Rows
Add the .uk-form-row
class to a <div>
element to stack form controls.
Example
Markup
<form class="uk-form">
<fieldset>
<legend>...</legend>
<div class="uk-form-row">...</div>
<div class="uk-form-row">...</div>
</fieldset>
</form>
Control states
Provide the user with basic information through feedback states on form controls.
Disabled
Add the disabled
attribute to a form control and it will be appear muted.
Example
Markup
<input type="text" placeholder="" disabled>
Validation states
Add the .uk-form-danger
or .uk-form-success
class to a form control to notify the user, whether or not the value is validated.
Example
Markup
<input type="text" placeholder="" class="uk-form-danger">
<input type="text" placeholder="" class="uk-form-success">
Control modifiers
Size modifiers
Add the .uk-form-large
or .uk-form-small
class to an <input>
, <select>
or <textarea>
element to make it smaller or larger.
Example
Markup
<input type="text" placeholder="" class="uk-form-large">
<input type="text" placeholder="" class="uk-form-small">
Width modifiers
Add the .uk-form-width-large
, .uk-form-width-medium
, .uk-form-width-small
or .uk-form-width-mini
class to an <input>
, <select>
or <textarea>
element to adjust its width.
Example
Markup
<input type="text" placeholder="" class="uk-form-width-large">
<input type="text" placeholder="" class="uk-form-width-medium">
<input type="text" placeholder="" class="uk-form-width-small">
<input type="text" placeholder="" class="uk-form-width-mini">
You can also apply the .uk-width-*
classes from the Grid component to form controls. This is especially useful, if you want form controls to extend to the full width of their parent container.
Example
Markup
<input type="text" placeholder="" class="uk-width-1-1">
Form blank
Add the .uk-form-blank
class to minimize the styling of form controls.
Example
Markup
<input type="text" placeholder="" class="uk-form-blank">
Help text
Use the .uk-form-help-inline
or .uk-form-help-block
class to add inline and block level help text for the controls.
Example
Markup
<div class="uk-form-row">
<input type="text" placeholder=""> <span class="uk-form-help-inline">...</span>
</div>
<div class="uk-form-row">
<textarea cols="" rows="" placeholder="">...</textarea>
<p class="uk-form-help-block">...</p>
</div>
Layout modifiers
There are two layout modifiers available: .uk-form-stacked
and .uk-form-horizontal
. Both require form controls to be wrapped with the .uk-form-row
class in order to stack them. Labels need the .uk-form-label
class and controls must be wrapped in the .uk-form-controls
class.
Markup
<form class="uk-form uk-form-stacked">
<div class="uk-form-row">
<label class="uk-form-label" for="">...</label>
<div class="uk-form-controls">...</div>
</div>
</form>
NOTE Layout modifiers can also be added to a <fieldset>
element. This means, if you use fieldsets, you can have different form layouts for each fieldset.
Form stacked
Add the .uk-form-stacked
class to display labels on top of controls.
Example
Form horizontal
Add the .uk-form-horizontal
class to display labels and controls side by side.
Example
Text in form controls
If you use text and checkboxes or radio buttons in form controls, just add the .uk-form-controls-text
class to align the text properly.
Markup
<div class="uk-form-controls uk-form-controls-text">...</div>
Vertical spacing in form controls
If you create paragraphs in form controls, add the .uk-form-controls-condensed
class to reduce spacing.
Example
Markup
<div class="uk-form-controls uk-form-controls-text">
<p class="uk-form-controls-condensed">...</p>
<p class="uk-form-controls-condensed">...</p>
</div>
Form and grid
This is an example of how to use forms with the Grid component.
Example
Markup
<form class="uk-form">
<div class="uk-grid">
<div class="uk-width-1-2"><input type="text" placeholder="" class="uk-width-1-1"></div>
<div class="uk-width-1-4"><input type="text" placeholder="" class="uk-width-1-1"></div>
<div class="uk-width-1-4"><input type="text" placeholder="" class="uk-width-1-1"></div>
</div>
</form>
Form and icons
This is an example of how to add an icon from the Icon component to a form.
Example
Markup
<div class="uk-form-icon">
<i class="uk-icon-calendar"></i>
<input type="text">
</div>
Form advanced
The form can be extended through the Form advanced component to style radio and checkbox inputs.