将列表从视图传递到控制器

时间:2014-08-04 08:20:18

标签: c# asp.net asp.net-mvc razor arraylist

我想从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");
}

这是插入多个条目的正确方法吗?或者是否有更好的解决方案将多个条目插入我的数据库?

2 个答案:

答案 0 :(得分:3)

我想你可能对MVC和EF有一些误解。您可能想要阅读更多有关这两个概念的内容。

首先,您的“模型”称为M_ARC,并且继承自DbContext。从DbContext继承的类不应该是模型,而是提供从/向数据库检索/更新模型的属性。

其次,您无法将数据从视图传递到控制器。这是相反的方式。当用户单击按钮时会发生什么,表单字段被发布到服务器并由控制器处理。我认为你试图实现的是渲染视图,使得表单字段具有正确的名称以映射到数组中。这不是一个新问题,你可以在这里找到一些帮助:MVC .NET Model Binding to Array on the fly

答案 1 :(得分:0)

我可以看到您要提交多个条目,其中每个条目都包含以下属性:PeriodeEmailSPDTJatuhTempoDTInformasiBankDT。以下是创建模型类的方法

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].EmailSPDTDetails[1].JatuhTempoDT,以便输入的值与{{1}中的顺序完全相同属性。