有关更新asp.net mvc中的项目列表的快速问题。
基本上我有一个返回对象集合的编辑操作方法(顺便提一下,其表结构如下所示'testID,assetID,Result' - 一个链接表)。
我基本上希望这些项目在表单中一个接一个地显示,并且能够编辑它们。表格应该回发并且模型绑定器发挥其魔力。但是,它并不那么容易。
我已经在网上搜索过了,似乎关于这些东西的大部分信息似乎都有点过时了。我遇到了this post,它在很长一段时间内没有更新,this one似乎暗示你不应该绑定到已经存在的更新列表,并且存在问题当使用EF或Linq到Sql(我是)时。
有没有一种简单的方法来实现我想要的?发布版本中列表模型绑定的状态是否已更改?
更新 - 更近一点......
这是我的编辑方法:
public ActionResult EditSurveyResults(Guid id)
{
var results = surveyRepository.GetSurveyResults(id);
return PartialView("EditSurveyResults", results);
}
我的表格:
<div id="editSurveyResults">
<h2>
EditSurveryResults</h2>
<%= Html.ValidationSummary("Edit was unsuccessful. Please correct the errors and try again.") %>
<% using (Html.BeginForm())
{%>
<fieldset>
<legend>Results</legend>
<% int i = 0; foreach (var result in Model)
{ %>
<input type="hidden" name='results[<%= i %>].TestID' value='<%= result.TestID %>' />
<input type="hidden" name='results[<%= i %>].AssetID' value='<%= result.AssetID %>' />
<p>
<%= result.Task.TaskName%>
</p>
<p>
<label for="Result">
Result:</label>
<input type="text" name='results[<%= i %>].Result' value='<%= result.Result %>' />
<%= Html.ValidationMessage("Result", "*")%>
</p>
<% i++; } %>
<p>
<input type="submit" value="Save" />
</p>
</fieldset>
<% } %>
我的编辑POST方法:
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult EditSurveyResults(Guid id, IList<SurveyTestResult> results)
{
var oldValues = surveyRepository.GetSurveyResults(id);
if (ModelState.IsValid)
{
UpdateModel(oldValues);
surveyRepository.Save();
return Content("Done");
}
else
return PartialView("EditSurveyResults");
}
它当然不完整,但它不会更新当前状态的任何内容。我在这里错过了一招吗?结果用更新的实体填充,所以我不确定为什么它不更新......
更新2: 所以,我开始认为模型绑定器不能做这样的事情。所以,我采取了更加黑客的方式做事。如果有人能发现问题,请告诉我。仅供参考 - 这个表格将被AJAX抓取,所以我不会返回一个视图,而是一个简单的消息。 这是新代码:
IList<SurveyTestResult> oldValues = surveyRepository.GetSurveyResults(id).ToList();
foreach (var result in SurveyTestResult)
{
//SurveyTestResult is the IList that comes down from the form.
SurveyTestResult thisone = oldValues.Single(p => p.AssetID == result.AssetID &&
p.TestID == result.TestID);
//update the old entity with the result from the new one
thisone.Result = result.Result;
}
然后我在我的存储库中调用Save。
提前致谢
答案 0 :(得分:5)
我注意到的一件事是,您不会将<input type="hidden" name='results.Index' value='<%= i %>' />
呈现为phil Haacks文章提及是强制性的。
切换到不同的Modelbinder也可以做到这一点。我使用DataAnnotations模型绑定器,在绑定到.Index
时,我不必生成List
个字段。