# Input ```rust demo let value = RwSignal::new(String::from("o")); view! { } ``` ## Prefix & Suffix ```rust demo let value = RwSignal::new(String::from("o")); view! { "$" ".00" } ``` ### Disabled ```rust demo let value = RwSignal::new(String::from("o")); view! { } ``` ### Placeholder ```rust demo view! { } ``` ### Imperative handle ```rust demo let value = RwSignal::new(String::from("o")); let input_ref = ComponentRef::::new(); let focus = move |_| { input_ref.get_untracked().unwrap().focus() }; let blur = move |_| { input_ref.get_untracked().unwrap().blur() }; view! { } ``` ### Input attrs ```rust demo view! { } ``` ### Input Props | Name | Type | Default | Description | | --- | --- | --- | --- | | class | `OptionalProp>` | `Default::default()` | Addtional classes for the input element. | | value | `Model` | `Default::default()` | Set the input value. | | variant | `MaybeSignal` | `InputVariant::Text` | Input's variant. | | placeholder | `OptionalProp>` | `Default::default()` | Placeholder of input. | | disabled | `MaybeSignal` | `false` | Whether the input is disabled. | | invalid | `MaybeSignal` | `false` | Whether the input is invalid. | | allow_value | `Option>` | `None` | Check the incoming value, if it returns false, input will not be accepted. | | on_focus | `Option>` | `None` | Callback triggered when the input is focussed on. | | on_blur | `Option>` | `None` | Callback triggered when the input is blurred. | | attr: | `Vec<(&'static str, Attribute)>` | `Default::default()` | The dom attrs of the input element inside the component. | ### Input Slots | Name | Default | Description | | ----------- | ------- | -------------------- | | InputPrefix | `None` | InputPrefix content. | | InputSuffix | `None` | InputSuffix content. | ### Input Ref | Name | Type | Description | | ----- | ----------- | ------------------------ | | focus | `Fn(&self)` | Focus the input element. | | blur | `Fn(&self)` | Blur the input element. | ### TextArea Props Removes variant and slot from Input component.