如何在Razor编辑视图中显示选中的单选按钮Asp Net Core MVC

时间:2019-02-06 07:07:42

标签: c# razor asp.net-core radio-button asp.net-core-mvc

尽管在Razor视图中具有Asp净核心代码:

@model List<SelectListItem>
<form asp-controller="Manage" asp-action="Change" method="post">
    @foreach (SelectListItem item in Model) {
        <br />
        <input asp-for="@item.Value" type="radio" value="@item.Value" /> @(item.Value + " - " + item.Text)
   }
   <br />
   <input type="submit" value="OK" />
</form>

在浏览器中选中所有单选按钮->查看源代码

<input type="radio" value="1001" checked="checked" id="item_Value" name="item.Value" /> 1001 - Vilnius<br />
<input type="radio" value="1002" checked="checked" id="item_Value" name="item.Value" /> 1002 - Palanga<br />

如何检查所有单选按钮?

添加:

var lst = new List<SelectListItem>() {
           new SelectListItem {
                Value = "1001",
                Text = "Vilnius",
                Selected = true
            },
            new SelectListItem {
                Value = "1002",
                Text = "Trakai",
                Selected = false
            }
        };

2 个答案:

答案 0 :(得分:1)

据我所知,之所以设置checked="checked"属性是因为这些单选按钮的当前值等于模型值(在标记帮助器的asp-for属性中分配的属性)。因此,您当前使用asp-for="@item.Value"进行的设置在这里是错误的:

<input asp-for="@item.Value" type="radio" value="@item.Value" />

如果您要基于Selected实例内的SelectListItem属性设置其值,则需要将viewmodel类中的属性用于asp-for属性中(该属性必须定义为value类型或字符串)。

以下是正确的示例设置:

模型

// Viewmodel class
public class ViewModel
{
    // used to store selected value in select tag helper
    public string SelectedValue { get; set; }

    public List<SelectListItem> OptionList { get; set; }
}

控制器操作

// Populate select list
[HttpGet]
public IActionResult Change()
{
    var model = new ViewModel();
    model.OptionList = new List<SelectListItem>();

    // populate list values here
    model.OptionList.Add(new SelectListItem { Text = "1001", Value = "Vilnius", Selected = true });
    model.OptionList.Add(new SelectListItem { Text = "1002", Value = "Trakai", Selected = false });

    return View(model);
}

查看

@* Set viewmodel property into tag helper *@
@model ViewModel

<form asp-controller="Manage" asp-action="Change" method="post">
    @foreach (var item in Model.OptionList) 
    {
        <br />
        <input asp-for="SelectedValue" type="radio" value="@item.Value" /> @(item.Value + " - " + item.Text)
    }
    <br />
    <input type="submit" value="OK" />
</form>

相关问题:

Radio Button Tag Helper sets every radio button to checked

答案 1 :(得分:0)

谢谢。就我而言

<input asp-for="@item.Value" type="radio" value="@item.Value" /> @(item.Value + " - " + item.Text)

更改为

<input asp-for="@item.Text" type="radio" value="@item.Value" /> @(item.Value + " - " + item.Text)

和控制器

[HttpPost]
[ValidateAntiForgeryToken]
public async Task<IActionResult> ChangeKomanda(SelectListItem item) {
   // use item.Text instead of item.Value

可以帮助某人