如何在 ASP.Net MVC 中制作布尔 HTML5 属性“有条件”?

Kee*_*ker 5 html c# asp.net asp.net-mvc razor

我正在使用 ASP.Net MVC (5.2.3.0) 创建一个表单字段:

@Html.TextBoxFor(
    x => x.UserName, 
    new { 
        @class = "form-control", 
        placeholder = "Enter your username", 
        required = true, 
        autofocus = true 
});
Run Code Online (Sandbox Code Playgroud)

到目前为止一切顺利,但现在我喜欢将autofocus属性设置为conditional。我该怎么办?

autofocus属性是一个布尔属性,W3C声明:

注意:布尔属性不允许使用值“true”和“false”。要表示假值,必须完全省略该属性。

以下在 MVC 中不起作用,因为它仍然呈现autofocus导致浏览器执行自动聚焦的属性:

autofocus = String.IsNullOrEmpty(this.Model.UserName)
autofocus = String.IsNullOrEmpty(this.Model.UserName) ? null : ""`
Run Code Online (Sandbox Code Playgroud)

有谁知道如何解决这个问题?

Lin*_*ell 5

您可以在视图之前的某处创建一个属性字典:

@{
    var usernameAttrs = new Dictionary<string, object>
    {
        {"class ", "form-control"},
        {"placeholder  ", "Enter your username"},
        {"required", true},
    };

    if (String.IsNullOrEmpty(this.Model.UserName))
    {
        usernameAttrs.Add("autofocus", true);
    }
}
Run Code Online (Sandbox Code Playgroud)

并在 TextBoxFor()

@Html.TextBoxFor(x => x.UserName, usernameAttrs);
Run Code Online (Sandbox Code Playgroud)