有很多关于这个问题的帖子,但我仍然找不到正确的解决方案。目前我的模型,视图和控制器看起来像这样:
查看:
@model Pro.Web.Models.CatDetailsView
@using (Html.BeginForm("Details", "Cat", Model, FormMethod.Post))
{
@Html.AntiForgeryToken()
@Html.ValidationSummary()
<h2>Details</h2>
<ol>
<li>
@Html.LabelFor(model => model.Cat.Name)
<p>@Html.DisplayFor(model => model.Cat.Name, new { @readonly = "true" })</p>
</li>
<li>
@Html.LabelFor(model => model.Cat.Owner)
<p>@Html.DisplayFor(model => model.Cat.Owner.UserName, new { @readonly = "true" })</p>
</li>
<li>
@Html.LabelFor(model => model.Cat.BornDate)
<p>@Html.DisplayFor(model => model.Cat.BornDate, new { @readonly = "true" })</p>
</li>
<li>
@Html.LabelFor(model => model.Cat.Age)
<p>@Html.DisplayFor(model => model.Cat.Age, new { @readonly = "true" })</p>
</li>
<li>
@Html.LabelFor(model => model.Cat.CatColorValue)
<p>@Html.DisplayEnumFor(model => model.Cat.CatColorValue, typeof(Pro.Web.Models.Entities.Enums.CatColor))</p>
</li>
<li>
@Html.LabelFor(model => model.Cat.Description)
<p>@Html.DisplayFor(model => model.Cat.Description, new { @readonly = "true" })</p>
</li>
</ol>
<input type="submit" value="Edit details" name="Command" />
}
型号:
public class CatDetailsView
{
public Cat Cat { get; set; }
}
控制器:
[HttpPost]
public ActionResult Details(CatDetailsView model, string Command)
{
if (Command.Equals("Edit details"))
{
Cat cat = this._catRepository.Find(model.Cat.Id);
if (cat != null)
{
return RedirectToAction("Edit", "Cats", new { id = cat.Id });
}
else
{
return View(model);
}
}
else
{
return View(model);
}
}
问题是控制器总是为模型接收null。我正在查看该代码,看不出有什么问题。我刚刚开始学习,所以我可能会遗漏一些微不足道的东西。我希望有人知道可能存在什么问题。
谢谢。
答案 0 :(得分:4)
您正在使用DisplayFor而不是EditorFor,因此您不会提交任何内容。
DisplayFor用于显示数据。
EditorFor用于添加表单输入元素,如文本框,单选按钮,复选框等。
修改强>
sormii在评论中提到了这一点,所以我将其添加到答案中。如果您希望用户能够更改发布的值,那么您应该使用EditorFor,但如果您只想向他们显示数据(不允许他们更改),那么您可以在每个DisplayFor之后立即使用HiddenFor。这将放置一个隐藏的输入,将被发布。
看起来你正在尝试使用readonly = true,所以我想你可能想要使用TextBoxFor来做到这一点。