Sam*_*mWM 9 asp.net-mvc entity-framework
使用实体数据框架,我有一个被定义的模型Client,它只包含一个id和一个名字.然后,我与另一个名为Appointment包含id和日期的模型有关联.
对于表单,我希望允许用户创建一个新客户端,并在同一表单上添加约会(在创建客户端之前).我有部分工作(增加一个约会).
在控制器中:
[HttpPost]
public ActionResult Create(Client client)
{
var appointment = new Appointment();
UpdateModel(appointment);
client.Appointments.Add(appointment);
db.AddToClients(client);
db.SaveChanges();
return RedirectToAction("Index");
}
Run Code Online (Sandbox Code Playgroud)
在视图中:
<div class="editor-label">
<%= Html.LabelFor(model => model.Name) %>
</div>
<div class="editor-field">
<%= Html.TextBoxFor(model => model.Name) %>
<%= Html.ValidationMessageFor(model => model.Name) %>
</div>
<% Html.RenderPartial("Appointment", new Appointment()); %>
Run Code Online (Sandbox Code Playgroud)
'部分'观点:
<div class="editor-label">
<%= Html.LabelFor(model => model.AppointmentDate) %>
</div>
<div class="editor-field">
<%= Html.TextBoxFor(model => model.AppointmentDate) %>
<%= Html.ValidationMessageFor(model => model.AppointmentDate) %>
</div>
Run Code Online (Sandbox Code Playgroud)
但是,由于以下几个原因,这并不理想:
Comments在两个Client和Appointment表中都调用了一个字段),则会出现问题,因为字段名称没有进行前缀,这也会阻止添加多个约会我可以做些什么来允许添加多个约会,即当点击"新约会"以允许尽可能多的约会时,使用按钮呈现页面上的部分视图(可能使用AJAX)?我还希望这是一个共享视图,可用于创建和编辑记录以及以相同的形式添加/删除约会.
使用ViewModel 更新一些进度:
public class ClientViewModel
{
public Client Client { get; set; }
public List<Appointment> Appointments { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
控制器:
public ActionResult Create()
{
Client c = new Client();
List<Appointment> appointments = new List<Appointment>();
appointments.Add(new Appointment() { AppointmentDate = DateTime.Now });
appointments.Add(new Appointment() { AppointmentDate = DateTime.Now.AddMonths(1) });
var model = new ClientViewModel
{
Client = c,
Appointments = appointments
};
return View(model);
}
[HttpPost]
public ActionResult Create(ClientViewModel m)
{
try
{
foreach (var appointment in m.Appointments)
{
m.Client.Appointments.Add(appointment);
}
db.AddToClients(m.Client);
db.SaveChanges();
return RedirectToAction("Index");
}
catch
{
return View();
}
}
Run Code Online (Sandbox Code Playgroud)
查看(对于约会,不适用于foreach循环,因为每个约会都以前缀为前缀Appointment_而不是Appointment[0]_):
<%= Html.EditorFor(model => Model.Client) %>
<% for (int i = 0; i < Model.Appointments.Count(); i++) { %>
<%= Html.EditorFor(model => Model.Appointments[i])%>
<% } %>
Run Code Online (Sandbox Code Playgroud)
这适用于为新客户创建约会,但是如何编辑它们,以及添加新约会而不回发表单?添加时,显示现有约会表单下的新约会表单的链接,另一个要删除的链接(隐藏视图并设置隐藏字段值).
更新2
让它工作,在首次创建客户端时添加约会.但是,我不确定如何更新现有约会(不仅删除所有约会并再次添加).
在控制器中:
[HttpPost]
public PartialViewResult AddAppointment(Appointment appointment, int index)
{
List<Appointment> appointments = new List<Appointment>();
for (int i = 0; i < index; i++)
{
appointments.Add(null);
}
appointments.Add(new Appointment() { AppointmentDate = DateTime.Now });
ViewData["index"] = index;
var model = new ClientViewModel
{
Appointments = appointments
};
return PartialView("Appointment", model);
}
Run Code Online (Sandbox Code Playgroud)
视图:
<%= Html.EditorFor(model => Model.Client) %>
<div id="appointments">
<% for (int i = 0; i < Model.Appointments.Count(); i++) { %>
<%= Html.EditorFor(model => Model.Appointments[i]) %>
<% } %>
</div>
<a href="javascript:;" id="addappointment">Add Appointment</a>
<script type="text/javascript">
var appIndex = <%= Model.Appointments.Count() %>;
$("#addappointment").click(function () {
$.post(
"/Client/AddAppointment",
{"index" : appIndex},
function (result) {
$("#appointments").append(result);
// increase index by 1
appIndex++;
}
);
});
Run Code Online (Sandbox Code Playgroud)
只是漂浮一些想法..
如果您使约会部分视图包含一个表单怎么样?
使用 jQuery/AJAX 处理表单的提交:
$.post(
"/SomeController/AddAppointment",
appointment, // grab this from the form
function (result) {
$("#target").html(result); // this will be the div which contains the partial
}
);
Run Code Online (Sandbox Code Playgroud)
这会将强类型约会发送到以下 Action 方法:
[HttpPost]
public PartialViewResult AddAppointment(Appointment appointment)
{
// code to persist entity
// code to add errors to model (if necessary)
return PartialView("Appointment");
}
Run Code Online (Sandbox Code Playgroud)
基本上,您使用 AJAX 提交表单,然后将结果重新渲染回部分。结果类似于 AJAX UpdatePanel(以 WebForms 闻名)。
因此,您需要填写详细信息,点击“提交”,详细信息将发布到控制器(使用 AJAX),然后表单将再次变为空白,以便您可以继续添加约会。
那行得通吗?
| 归档时间: |
|
| 查看次数: |
5174 次 |
| 最近记录: |