当checked属性为false时默认选中单选按钮?

Nav*_*mar 3 c# asp.net asp.net-mvc razor asp.net-mvc-4

我正在尝试生成单选按钮,如果该值存在于数据库中,则有条件地检查已检查的属性,则应选择它,否则已检查的属性为假。所以最初数据库中没有行,所有单选按钮的checked属性也为false,但它仍然在UI上被选中,见下图

在此处输入图片说明

所以不知道这是默认行为还是遗留的任何错误,下面是我的代码

视图模型

public class CompanionProductVersion1ViewModel
{
    [Required(ErrorMessage = "Please select companion release - 1")]
    public string CompanionReleaseRadio1 { get; set; }
    public List<CompanionReleaseRadio1> CompanionReleaseRadios1 { get; set; }
}

public class CompanionReleaseRadio1
{
    public string RadioID { get; set; }
    public string RadioText { get; set; }
    public bool Checked { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

看法

@model PlatformLifecyclePortal.Web.ViewModel.CompanionProductVersion1ViewModel

<div class="mt-5">
    <div class="d-flex pb-3">
        <h2>Companion Release - 1</h2>
    </div>

    <div class="border border-dark p-5">
        <div class="row"><h6><b>@Session["Release"]</b></h6></div>
        <div class="row"><p><b>@Session["Feature"]</b></p></div>
        <div class="row">@Html.ValidationMessageFor(m => m.CompanionReleaseRadio1, "", new { @class = "help-block text-danger", @style = "color:red;" })</div>
        <div class="row"><div class="col-sm-9">&nbsp;</div></div>

        <div class="row">

            @using (Html.BeginForm())
            {
                <div class="form-group row">
                    @foreach (var companionReleases1 in Model.CompanionReleaseRadios1)
                    {
                        <div class="col-sm-4">
                            @Html.RadioButtonFor(model => Model.CompanionReleaseRadio1, companionReleases1.RadioID, new { id = "CompanionReleaseRadio2" + companionReleases1.RadioID, @checked = companionReleases1.Checked }) <span class="checkbox-label">@companionReleases1.RadioText</span>
                        </div>
                    }
                </div>

                <div class="row">
                    <div class="col-sm-9">
                        <button type="submit" class="btn btn-primary btn-next">Next</button>
                    </div>
                </div>
            }
        </div>
    </div>
</div>
Run Code Online (Sandbox Code Playgroud)

Tet*_*oto 5

通过检查checked单选按钮的属性行为,我发现您的问题发生是因为checked属性是一个布尔属性,当该属性存在时,表示相应的输入元素处于选中状态,无论其值如何(checked="false"checked="true"或相同checked="checked")。

如果checked同一组中的多个单选按钮存在属性,默认情况下它将最后一个单选按钮设置为checked(根据您的原始代码查看此小提琴)。因此,checkedCompanionReleaseRadio1.Checked属性设置为 false时,您需要使用@functions以下示例中提供的内联函数助手来排除属性:

@functions {
    private object SetRadioButtonChecked(bool isChecked, string RadioID) 
    {
        // checked state from property
        if (isChecked)
        {
            // checked attribute is present
            return new { id = "CompanionReleaseRadio2" + RadioID, @checked = "checked" };
        }
        else
        {
            // checked attribute is not present
            return new { id = "CompanionReleaseRadio2" + RadioID };
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

然后RadioButton像这样在helper内部调用上面的内联函数:

@foreach (var companionReleases1 in Model.CompanionReleaseRadios1)
{
    <div class="col-sm-4">
        @Html.RadioButtonFor(model => Model.CompanionReleaseRadio1, companionReleases1.RadioID, 
             @SetRadioButtonChecked(companionReleases1.Checked, companionReleases1.RadioID)) 
        <span class="checkbox-label">@companionReleases1.RadioText</span>
    </div>
}
Run Code Online (Sandbox Code Playgroud)

之后,所有CompanionReleaseRadio1.Checked属性设置为的单选按钮都false应该设置为未选中状态(有关预期结果,请参阅此小提琴)。

参考:

在带有 Razor 语法的 ASP.NET 页面中使用 @functions

相关问题:

如何在 cshtml 模板中创建函数?

asp.net mvc3 基于模型检查单选按钮