Ser*_*gio 3 asp.net-mvc list model-binding
有关更新asp.net mvc中项目列表的快速问题.
基本上我有一个返回对象集合的编辑操作方法(顺便提一下,其表结构如下所示'testID,assetID,Result' - 一个链接表).
我基本上希望这些项目在表单中一个接一个地显示,并且能够编辑它们.表格应该回发并且模型绑定器发挥其魔力.但是,它并不那么容易.
我已经在网上搜索了,似乎关于这些东西的大部分信息似乎有点过时了.我碰到过这个帖子,已经在不长的时间没有更新,而这一次,这似乎表明,你不应该绑定到现有列表更新,并有与EF或LINQ工作时的问题到Sql(我是).
有没有一种简单的方法来实现我想要的?发布版本中是否更改了列表模型绑定的状态?
更新 - 更近一点......
这是我的编辑方法:
public ActionResult EditSurveyResults(Guid id)
{
var results = surveyRepository.GetSurveyResults(id);
return PartialView("EditSurveyResults", results);
}
Run Code Online (Sandbox Code Playgroud)
我的形式:
<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>
<% } %>
Run Code Online (Sandbox Code Playgroud)
我的编辑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");
}
Run Code Online (Sandbox Code Playgroud)
它当然不完整,但它不会更新当前状态的任何内容.我在这里错过了一招吗?结果填充了更新的实体,所以我不确定为什么它不更新...
更新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;
}
Run Code Online (Sandbox Code Playgroud)
然后我在我的存储库上调用Save.
提前致谢
| 归档时间: |
|
| 查看次数: |
10345 次 |
| 最近记录: |