这是我的代码:
模型:
[required] [DataType(DataType.Text)] [Display(Name = "Your company's name")] public string CompanyName { get; set; }
视图:
@Html.TextBoxFor(m => m.CompanyName,new { @class = "account-input",@placeholder = @Html.DisplayNameFor(m => m.CompanyName),@id = "companyname" })
它将呈现如下:
Your company's name
html输出:
<input class="account-input" data-val="true" data-val-required="The Your company's name field is required." id="companyname" name="CompanyName" placeholder="Your company&#39;s name" type="text" value="">
应该是这样的:
Your company’s name
为什么文本无法正确呈现,如何防止这种情况?
我已经尝试过:
@Html.TextBoxFor(m => m.CompanyName,@placeholder = @Html.Raw(@Html.DisplayNameFor(m => m.CompanyName)),@id = "companyname" })
和这个
@Html.TextBoxFor(m => m.CompanyName,@placeholder = @Html.Encode(@Html.DisplayNameFor(m => m.CompanyName)),@id = "companyname" })
解决方法
我觉得这篇文章可以帮助你:
我认为还有其他方法可以得到这个行为,但这是使用TextBox的一个选择:
@Html.TextBox("CompanyName",HttpUtility.HtmlEncode("Your company's name"))
还有HttpUtility.HtmlDecode,这可能有助于我们的保存操作。
更新
如果您在您的占位符周围包装HttpUtility.HtmlDecode:
@Html.TextBoxFor(m => m.CompanyName,@placeholder = HttpUtility.HtmlDecode(Html.DisplayNameFor(x => x.CompanyName).ToHtmlString()),@id = "companyname" })
占位符返回:占位符=“您公司的名称”