Html.TextBoxFor(m => m.Student.FirstName,新的{ id = "FirstName",disabled =“FirstName”})
我想禁用文本框,所以我使用了上面所述的禁用attr,但在保存表单时,上面文本框中加载的值变为null。
任何一个人都知道发生了什么
谢谢
发布于 2012-01-24 22:45:46
这是故意的。禁用的输入不会回发到服务器。
您可以使用“只读”来输入“只读”。这将允许回发数据,但用户不能以传统的方式编辑信息。
<input type="text" name="foo" value="Some Value" readonly="readonly" />请记住,人们可以使用像Firebug或蜻蜓这样的工具来编辑数据并将其发回。所以,保持警惕,或者确保数据是相同的,或者更好的是,只使用禁用的属性。
发布于 2014-08-08 09:32:17
您可以在@Html.TextBoxFor中尝试这种方法。
Html.TextBoxFor(m => m.Student.FirstName, new { id = "FirstName", ,@readonly="readonly" })发布于 2012-01-24 22:44:29
HTML规范说禁用的输入不会发布它们的值。如果您想要在客户端持久化,则需要创建一个隐藏的输入来伴随这个值。
然而,这可能不是你想要的。如果您已经禁用了textbox,您可能并不打算让用户更改这个值,但是没有什么可以阻止他们使用Firebug或类似的浏览器工具来重新启用输入并发送不同的值。最好是在模型服务器端使用与最初获取该值相同的方法填充该值。
https://stackoverflow.com/questions/8995336
复制相似问题