我已经为此工作了几个小时。我有下面的部分视图
_Partial.cshtml
@model project.Jobs
@using (Html.BeginCollectionItem("Jobs"))
{
<tr id="jobrow">
<td>
@Html.HiddenFor(modelItem => modelItem.JobId)
@Html.EditorFor(modelItem => modelItem.Description, new { htmlAttributes = new { @class = "" } })
</td>
<td>
@Html.EditorFor(modelItem => modelItem.FlatRate, new { htmlAttributes = new { @class = "", type = "number", min = "0.00" } })
</td>
<td>
@Html.EditorFor(modelItem => modelItem.StandardHour, new { htmlAttributes = new { @class = "", type = "number", min = "0.00" } })
</td>
<td>
@Ajax.ActionLink("Click Me", "AddRepairOrderJobs", "RepairOrderWizard", Model, new AjaxOptions { InsertionMode = InsertionMode.InsertAfter, UpdateTargetId = "rodetailrowdata", HttpMethod = "POST" })
</td>
</tr>
}
这是我渲染局部视图的地方
Main View.cshtml
@model project.MainViewModel
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<table id="mygrid" class="table">
<thead>
<tr>
<th>Description</th>
<th>Flat Rate</th>
<th>Standart Time</th>
<th>Charge To</th>
<th></th>
</tr>
</thead>
<tbody id="rodetailrowdata">
@foreach (var item in Model.MainViewModel.Jobs)
{
@Html.Partial("_Partial", item)
}
</tbody>
</table>
使用下面的操作方法,我可以使用上面的ajax.actionlink将来自editorfor标签的现有数据从局部视图传递到控制器
Controller.cs
[HttpPost]
public PartialViewResult AddRepairOrderJobs(Jobs job)
{
var x = new OtherModel(){
JobId = job.JobId,
Name = job.Description,
SelectedRate = job.FlatRate
StandardHour = job.StandardHour
}
return PartialView("_HeaderDetailList", x);
}
现在,我想做的是,当我修改editorfor的值时,我会从 _Partial.cshtml 中获取更新的数据,而不是单击操作链接时的旧数据,但是我可以不要让它工作。 我该怎么做而又不做一些“黑客工作”呢?
编辑:我已经添加了用于加载作业列表的操作方法
public ActionResult NewRecord()
{
var add= new MainViewModel()
{
//other data,
Jobs = jobrepository.GetAllJobs()
};
return View(add);
}
答案 0 :(得分:0)
我使用@ Tomato32的技巧解决了我的问题。我只需要将Jobs模型放入主视图而不是局部视图中,然后将其循环通过,然后将viewmodel作为参数而不是Jobs模型传递。现在,我将获得所有信息,包括更新的乔布斯数据。如果有人需要,我可以提供代码。