Input

Renders an input with label and error messages.

Read more Read less

A Phoenix.HTML.FormField may be passed as argument, which is used to retrieve the input name, id, and values. Otherwise all attributes may be passed explicitly.

Types

This function accepts all HTML input types, considering that:

  • You may also set type="select" to render a <select> tag
  • type="checkbox" is used exclusively to render boolean values
  • For live file uploads, see Phoenix.Component.live_file_input/1

See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input for more information. Unsupported types, such as hidden and radio, are best written directly in your templates.

Examples

<.input field={@form[:email]} type="email" />
<.input name="my-input" errors={["oh no!"]} />
<.simple_form :let={f} for={%{}} as={:story} class="w-full">
  <.input field={f[:field]} id="input-basic-inputs-text" label="Text input" type="text"/>
  <.input field={f[:field]} id="input-basic-inputs-textarea" label="Textarea input" type="textarea"/>
  <.input field={f[:field]} id="input-basic-inputs-number" label="Number input" type="number"/>
  <.input field={f[:field]} id="input-basic-inputs-date" label="Date input" type="date"/>
  <.input field={f[:field]} id="input-basic-inputs-color" label="Color input" type="color"/>
  <.input field={f[:field]} id="input-basic-inputs-range" label="Range input" type="range"/>
  <.input field={f[:field]} id="input-basic-inputs-checkbox" label="Checkbox input" type="checkbox"/>
</.simple_form>
<.simple_form :let={f} for={%{}} as={:story} class="w-full">
  <.input field={f[:field]} id="input-single-select" label="Select input" type="select" options={["Option 1", "Option 2", "Option 3"]}/>
</.simple_form>