在我的主编辑视图中,我有3个部分视图,其中包含主视图模型的子数据。我还有html文本框,用于输入和保存相关数据,如笔记等。 输入项目或选择并传递给控制器操作后,如何刷新部分视图?这是我到目前为止的代码,但它不起作用。我想我需要通过部分视图传回一个模型? 我使用ajax来调用我的控制器方法。 部分观点:
@model cummins_db.Models.CaseComplaint
<table width="100%">
<tr>
<td>
@Html.DisplayFor(modelItem => Model.ComplaintCode.ComplaintCodeName)
</td>
<td>
@Html.DisplayFor(modelItem => Model.ComplaintCode.ComplaintType)
</td>
</tr>
</table>
这是部分视图所在的html:
<div class="editor-label">
@Html.Label("Search and select a complaint code")
</div>
<div class="textarea-field">
<input id = "CodeByNumber" type="text" />
</div>
@Html.ActionLink("Refresh", "Edit", new { id = Model.CasesID })
<table width="100%">
<tr>
<th>Complaint Code</th>
<th>Complaint Description</th>
</tr>
@try
{
foreach (var comp_item in Model.CaseComplaint)
{
<div id="complaintlist">
@Html.Partial("_CaseComplaintCodes", comp_item)
</div>
}
}
catch
{
}
</table>
这是返回局部视图的控制器方法。
public ActionResult SelectForCase(int caseid, int compid, string compname)
{
if (ModelState.IsValid)
{
CaseComplaint c = new CaseComplaint
{
CasesID = caseid,
ComplaintCodeID = compid
};
db.CaseComplaints.Add(c);
db.SaveChanges();
}
return PartialView("_CaseComplaintCodes");
}
jQuery ajax调用控制器,它是自动完成函数select的一部分。
$('#CodeByNumber').autocomplete(
{
source: function (request, response) {
$.ajax({
url: "/Cases/CodeByNumber", type: "GET", dataType: "json",
data: { searchText: request.term, maxResults: 10 },
contentType: "application/json; charset=utf-8",
success: function (data) {
response($.map(data, function (item) {
return {
label: item.ComplaintType,
value: item.ComplaintCodeName,
id: item.ComplaintCodeID
}; //return
}) //map
); //response
} //success
}); //ajax
}, //source
select: function (event, ui) {
var url = "/Cases/SelectForCase";
$.ajax({
type: "GET",
dataType: "html",
url: url,
data: { caseid: $('#CaseID').val(), compid: ui.item.id, compname: ui.item.label },
success: function (result) { $('#complaintlist').html(result); }
});
},
minLength: 1
});
答案 0 :(得分:1)
部分视图不应如下所示:
@model cummins_db.Models.CaseComplaint
<table width="100%">
<tr>
<td>
@Html.DisplayFor(m => m.ComplaintCodeName)
</td>
<td>
@Html.DisplayFor(m => m.ComplaintType)
</td>
</tr>
</table>
答案 1 :(得分:0)
这是我最终做的工作。我通过控制器操作改为:
public ActionResult SelectForCase(int caseid, int compid)
{
if (ModelState.IsValid)
{
CaseComplaint c = new CaseComplaint
{
CasesID = caseid,
ComplaintCodeID = compid
};
db.CaseComplaints.Add(c);
db.SaveChanges();
var m = from d in db.CaseComplaints
where d.CasesID == caseid
select d;
return PartialView("_CaseComplaintCodes", m);
}
return PartialView("_CaseComplaintCodes");
}
现在可以使用