我想从ARCCreate传递一个ObjectList,这样项目就可以作为多个条目添加到数据库中,这些是我的代码:
我的模特:
public class M_ARC : DbContext
{
[Key]
[Display(Name = "Periode")]
[Required]
[RegularExpression("[2][0]([1][4-9]|[2-9][0-9])(0[1-9]|1[012])", ErrorMessage = "Format tidak sesuai. Contoh format : 201407 (Juli 2014)")]
public int Periode { get; set; }
[Display(Name = "Email SPDT")]
[Required]
[DataType(DataType.DateTime)]
[DisplayFormat(DataFormatString = "dd/MM/yyyy", ApplyFormatInEditMode = true)]
public DateTime EmailSPDT { get; set; }
[Display(Name = "Jatuh Tempo")]
[Required]
public DateTime JatuhTempoDT { get; set; }
}
我的观点:
<tr>
<th>
@Html.Label("Agustus")
</th>
<td>
<input type="text" name="EmailSPDT" class="pengirimanDT" />
</td>
<td>
<input type="text" name="JatuhTempoDT" class="tanggapanDT" />
</td>
<td>
<input type="text" name="InformasiBankDT" class="informasiBankDT" />
</td>
</tr>
<tr>
<th>
@Html.Label("September")
</th>
<td>
<input type="text" name="EmailSPDT" class="pengirimanDT" />
</td>
<td>
<input type="text" name="JatuhTempoDT" class="tanggapanDT" />
</td>
<td>
<input type="text" name="InformasiBankDT" class="informasiBankDT" />
</td>
</tr>
<tr>
<th>
@Html.Label("Oktober")
</th>
<td>
<input type="text" name="EmailSPDT" class="pengirimanDT" />
</td>
<td>
<input type="text" name="JatuhTempoDT" class="tanggapanDT" />
</td>
<td>
<input type="text" name="InformasiBankDT" class="informasiBankDT" />
</td>
</tr>
我的控制器:
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult ARCCreate(List<M_ARC> ARCList)
{
foreach (M_ARC item in ARCList)
{
if (ModelState.IsValid)
{
db.Arcs.Add(item);
db.SaveChanges();
}
else return View();
}
return RedirectToAction("ARCIndex");
}
这是插入多个条目的正确方法吗?或者是否有更好的解决方案将多个条目插入我的数据库?
答案 0 :(得分:3)
我想你可能对MVC和EF有一些误解。您可能想要阅读更多有关这两个概念的内容。
首先,您的“模型”称为M_ARC
,并且继承自DbContext
。从DbContext
继承的类不应该是模型,而是提供从/向数据库检索/更新模型的属性。
其次,您无法将数据从视图传递到控制器。这是相反的方式。当用户单击按钮时会发生什么,表单字段被发布到服务器并由控制器处理。我认为你试图实现的是渲染视图,使得表单字段具有正确的名称以映射到数组中。这不是一个新问题,你可以在这里找到一些帮助:MVC .NET Model Binding to Array on the fly
答案 1 :(得分:0)
我可以看到您要提交多个条目,其中每个条目都包含以下属性:Periode
,EmailSPDT
,JatuhTempoDT
和InformasiBankDT
。以下是创建模型类的方法
public class ARCCreateModel
{
public ARCCreateModel()
{
this.Details = new List<ARCCreateDetail>();
}
public List<ARCCreateDetail> Details { get; set; }
}
public class ARCCreateDetail
{
[Display(Name = "Periode")]
[Required]
[RegularExpression("[2][0]([1][4-9]|[2-9][0-9])(0[1-9]|1[012])", ErrorMessage = "Format tidak sesuai. Contoh format : 201407 (Juli 2014)")]
public int Periode { get; set; }
[Display(Name = "Email SPDT")]
[Required]
[DataType(DataType.DateTime)]
[DisplayFormat(DataFormatString = "dd/MM/yyyy", ApplyFormatInEditMode = true)]
public DateTime EmailSPDT { get; set; }
[Display(Name = "Jatuh Tempo")]
[Required]
public DateTime JatuhTempoDT { get; set; }
}
然后将ARCCreateModel
的实例传递给控制器get方法
[HttpGet]
public ActionResult ARCCreate()
{
ARCCreateModel model = new ARCCreateModel();
// generate the multiple entries
ARCCreateDetail detail1 = new ARCCreateDetail();
detail1.Periode = 201408;
model.Details.Add(detail1);
// add more details if necessary
ARCCreateDetail detail2 = new ARCCreateDetail();
detail2.Periode = 201409;
model.Details.Add(detail2);
return View(model);
}
根据上面ARCCreateModel
@model ARCCreateModel
@using (Html.BeginForm())
{
<table>
@for (int i = 0; i < Model.Details.Count; i++)
{
<tr>
<th>
@Model.Details[i].Periode
</th>
<td>
<input type="text" name="Details[@i].EmailSPDT" class="pengirimanDT" />
</td>
<td>
<input type="text" name="Details[@i].JatuhTempoDT" class="tanggapanDT" />
</td>
<td>
<input type="text" name="Details[@i].InformasiBankDT" class="informasiBankDT" />
</td>
</tr>
}
</table>
<button type="submit">Submit</button>
}
最后,当您提交表单时,您可以在model.Details
中获取多个条目,如下所示
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult ARCCreate(ARCCreateModel model)
{
foreach (ARCCreateDetail item in model.Details)
{
// get the entered values and save to database here
// assuming there's Arc table with properties similar to ARCCreateDetail
Arc arc = new Arc();
arc.Periode = item.Periode;
arc.EmailSPDT = item.EmailSPDT;
arc.JatuhTempoDT = item.JatuhTempoDT;
arc.InformasiBankDT = item.InformasiBankDT;
db.Arcs.Add(arc);
}
// submit the changes to EF
db.SaveChanges();
return RedirectToAction("ARCIndex");
}
请注意,关键是如何为每个条目设置文本框的名称属性,即Details[0].EmailSPDT
或Details[1].JatuhTempoDT
,以便输入的值与{{1}中的顺序完全相同属性。