Blazor - Get Started with Smart.Input
Setup The Project
Follow the Getting Started guide to set up your Blazor Application with Smart UI.
Setup Basic Input
Smart.Input is a custom input element with additional built-in features such as a drop down list with predefined options.
The list of avaible options is set using the DataSource property.
- Add the Input component to the Pages/Index.razor file
<Input></Input>
- Inside the
@code
block, create an array of elements and set it as DataSource of the component<Input DataSource="drinks" Placeholder="Type text here..."></Input> @code{ private string[] drinks = new string[]{"Water", "Juice", "Soda", "Tea", "Beer", "Wine", }; }
data:image/s3,"s3://crabby-images/33d8c/33d8c6617f3ecb5f5a38efe27c75a33792ff0bb0" alt="Basic input"
Input Customization
Smart.Input can be styled in different ways by setting the Class property.
The Input can be default
, outlined
or underlined
<Input DataSource="drinks" Placeholder="Type text here..." Class="underlined"></Input>
data:image/s3,"s3://crabby-images/9f93b/9f93b21333f60632f58595f8d0012927dfa9fa49" alt="Input modes"
Input Events
Smart.Input provides multiple events that can help you expand the component's functionality.
Each event object has unique event.detail parameters.
OnChange
- triggered when the selection is changed.
Event Details
: string label, dynamic oldLabel, dynamic oldValue, dynamic valueOnChanging
- triggered on each key up event of the Input, if the value is changed.
Event Details
: dynamic oldValue, dynamic valueOnItemClick
- triggered when the user clicks on an item from the popup list.
Event Details
: dynamic item, string label, dynamic value
The demo below uses the OnChanging
Event to display the previous value of the input field:
<h2>Previous value was:</h2> <h2>@oldValue</h2> <Input DataSource="drinks" Placeholder="Type text here..." OnChanging="OnChanging"></Input> @code{ private string[] drinks = new string[]{"Water", "Juice", "Soda", "Tea", "Beer", "Wine", }; string oldValue; private void OnChanging(Event ev) { if(ev.ContainsKey("Detail")){ InputChangingEventDetail detail = ev["Detail"]; oldValue = detail.OldValue; } } }
data:image/s3,"s3://crabby-images/dfc7a/dfc7af5081d1c2c824e5e64d125a79996c4cac81" alt="Input OnChanging event"
Two-way Value Binding
The Input component also supports two-way value binding:
<h3>@textValue</h3> <Input @bind-Value = "@textValue"></Input> @code{ string textValue = ""; }
data:image/s3,"s3://crabby-images/c1db2/c1db2ef8b7a8b821d51eb16268844539509e8bed" alt="Input value binding"