New to Telerik UI for ASP.NET Core? Start a free 30-day trial
Binding
When using the RadioGroup component, you can bind the radio button items by using the Items() method or the BindTo() method.
Items method
The example below demonstrates how to use the Items() method to configure the radio buttons in the RadioGroup widget.
Razor
@(Html.Kendo().RadioGroup()
.Name("radiogroup")
.Items(i =>
{
i.Add().Label("Phone (SMS)").Value("1");
i.Add().Label("E-mail").Value("2");
i.Add().Label("None").Value("3");
})
.Value("1")
)
BindTo method
You can configure the items in the RadioGroup widget by using the BindTo method.
-
Pass the data to the view through the view model.
Razorpublic ActionResult Index() { var itemsList = new List<InputGroupItemModel>() { new InputGroupItemModel() { Label = "Yes", Value = "one" }, new InputGroupItemModel() { Label = "No", Value = "two" }, new InputGroupItemModel() { Label = "N/A", Value = "three" } }; return View(new RadioGroupViewModel() { Items = itemsList }); } public class RadioGroupViewModel { public List<InputGroupItemModel> Items { get; set; } } public class InputGroupItemModel : IInputGroupItem { public IDictionary<string, object> HtmlAttributes { get; set; } public string CssClass { get; set; } public bool? Enabled { get; set; } public bool? Encoded { get; set; } public string Label { get; set; } public string Value { get; set; } }
-
Add the RadioGroup to the view and bind it to a property of the view model.
Razor@model MvcApplication1.Models.RadioGroupViewModel @(Html.Kendo().RadioGroup() .Name("radiogroup") .BindTo(Model.Items) )
Model Binding
You can implement model binding both with local and remote data.
The RadioGroup component is not accustomed to complex object-binding scenarios.
Model Binding with Local Data
Razor
@model RadioGroupModel
@(Html.Kendo().RadioGroupFor(model => model.RadioGroupGroupValue)
.Name("radiogroup")
.Items(items =>
{
items.Add().Label("Phone (SMS)").Value("1");
items.Add().Label("E-mail").Value("2");
items.Add().Label("None").Value("3");
})
)
Model Binding with Remote Data
Razor
@model RadioGroupModel
@(Html.Kendo().RadioGroupFor(model => model.RadioGroupGroupValue)
.HtmlAttributes(new { style = "height: auto;" })
.Layout(radiogroupLayout.Vertical)
.BindTo((List<IInputGroupItem>)ViewData["radiogroupItems"])
)