是否可以从控制器中的方法刷新编辑视图?
我有一个局部视图,它对控制器进行回调。从这个方法我想根据传递给这个方法的值刷新我的整个编辑视图。
public ActionResult AssignPractice(Guid id, Guid doctorId)
{
var doctorViewModel = Map.This(_doctorService.GetDoctor(doctorId)).To<DoctorViewModel>();
AddSelectLists(doctorViewModel);
var practice = _practiceService.GetPractice(id);
doctorViewModel.Practice = new PracticeSelectListViewModel()
{Item = practice, DoctorId = doctorId, SelectList = _practices};
return View("Edit", doctorViewModel);
}
提前致谢,
编辑:
我会详细说明一下。我面临的案例如下:
医生需要被分配一个练习,这不仅会影响医生的实践,还会影响我的医生视图模型上的其他20个属性,并且需要在视图中反映出来。也许我正在通过寻求上述解决方案来看错。
答案 0 :(得分:1)
如何使用jQuery加载函数调用控制器方法trhu JSON?您可以调用控制器方法,更新ViewModel并返回编辑视图或其他内容。
jQuery的:
$('#buttonToRefresh').click(function () {
$('#mainContent').load('@Url.Content("YourAction", "YourController")', $('#yourFormID').serialize());
});
查看:
<div id="mainContent">
@Html.BeginForm("Action", "Controller", FormMethod.Post, new { id = "yourFormID" })
{
// Your content goes here.
}
</div>
您的控制器保持不变。
答案 1 :(得分:0)
好的,所以我使用了一些所有解决方案来找到适合我案例的解决方案。
使用Javascript:
function Doctor() {
this.id = null;
this.FirstName = "";
this.LastName = "";
this.Code = "";
this.PhoneNumber = "";
this.PhoneNumber2 = "";
this.PhoneNumberActive = 0;
this.PhoneNumber2Active = 0;
this.Email = "";
this.Practice = new Practice();
function AssignPractice() {
var myModel = new Doctor();
myModel.id = Id.value;
myModel.FirstName = FirstName.lastChangedValue;
myModel.LastName = LastName.lastChangedValue;
myModel.Code = Code.lastChangedValue;
myModel.PhoneNumber = PhoneNumber.lastChangedValue;
myModel.PhoneNumber2 = PhoneNumber2.lastChangedValue;
myModel.PhoneNumberActive = PhoneNumberActive.lastChangedValue;
myModel.PhoneNumber2Active = PhoneNumber2Active.lastChangedValue;
myModel.Email = Email.lastChangedValue;
myModel.Practice.id = cbbPractice.lastSuccessValue;
var postData = JSON.stringify(myModel);
$.ajax({
url: assignPracticeUrl,
type: 'POST',
data: postData,
success: function (data) {
$('#yourFormID').html(data);
}
});
查看:
@using (Html.BeginForm("Edit", "Doctor", FormMethod.Post, new { id = "yourFormID" }))
控制器:
public ActionResult AssignPractice(FormCollection form)
{
JavaScriptSerializer js = new JavaScriptSerializer();
var doctor = js.Deserialize<Doctor>(form[0]);
var doctorViewModel = Map.This(_doctorService.GetDoctor(doctor.Id)).To<DoctorViewModel>();
AddSelectLists(doctorViewModel);
var practice = _practiceService.GetPractice(doctor.Practice.Id);
var practiceViewModel = Map.This(practice).To<PracticeViewModel>();
doctorViewModel.Practice = new PracticeSelectListViewModel() { Item = practice, SelectList = _practices };
doctorViewModel.FirstName = doctor.FirstName;
doctorViewModel.LastName = doctor.LastName;
doctorViewModel.PhoneNumber = doctor.PhoneNumber;
doctorViewModel.PhoneNumber2 = doctor.PhoneNumber2;
doctorViewModel.PhoneNumberActive = doctor.PhoneNumberActive;
doctorViewModel.PhoneNumber2Active = doctor.PhoneNumberActive;
doctorViewModel.Email = doctor.Email;
doctorViewModel.OpeningHours = practiceViewModel.OpeningHours;
doctorViewModel.AppointmentHours = practiceViewModel.AppointmentHours;
doctorViewModel.AddressViewModel = practiceViewModel.AddressViewModel;
doctorViewModel.Website = practiceViewModel.Website;
doctorViewModel.Labo = practiceViewModel.Labo;
doctorViewModel.KeyChain = practiceViewModel.KeyChain;
return PartialView("Edit", doctorViewModel);
}