如何在asp.net MVC 5中创建表单

时间:2014-04-08 15:51:23

标签: c# asp.net-mvc

我已经习惯了网络表单,但我转而使用MVC 5,并对创建多步申请表有疑问。

此表单就像一个向导,然后将显示最后在每个步骤中输入的信息,然后提交。

使用.cshtml中的html表单编写它是否更容易,或者在控制器中完成所有操作?

感谢你

2 个答案:

答案 0 :(得分:8)

MVC,顾名思义,有一个模型,一个视图和一个控制器。要创建表单,请设置一个将充当模型的类,其中包含需要在特定视图中使用的属性。这与实体不同,后者是与数据库中的表对应的类。您有时可以将实体用作模型,但特别是在多步形式的情况下,您不希望将数据持久到结束,这意味着它们需要分开。

这将我们带到视图模型的主题,它实际上来自另一种称为MVVM的模式。无论如何,这些视图的模型将是一系列视图模型,其中仅包含特定步骤需要收集的信息。最后,您将通过创建实体实例并将每个视图模型中的属性值映射到它来将所有收集的数据组合在一起。然后,您将保存实体。

现在,只要在请求之间保存收集的数据,那就是会话进入的地方。您只需将每个发布的视图模型添加到Session对象中,然后最后获取全部它们来自Session对象来创建您的实体。

因此,每个POST操作都将具有以下内容:

[HttpPost]
public ActionResult Step1(Step1ViewModel model)
{
    if (ModelState.IsValid)
    {
        Session["Step1"] = model;
        return RedirectToAction("Step2");
    }

    // errors
    return View(model);
}

然后,你最后的POST动作:

[HttpPost]
public ActionResult StepFinal(StepFinalViewModel)
{
    if (ModelState.IsValid)
    {
        var myEntity = new MyEntity();

        var step1 = Session['Step1'] as Step1ViewModel;
        myEntity.SomeField = step1.SomeField;
        // ... repeat for field in view model, then for each step


        db.MyEntities.Add(myEntity);
        db.SaveChanges();

        Session.Remove('Step1');
        // repeat for each step in session

        return RedirectToAction("Success");
    }

    // errors
    return View(model);
}

答案 1 :(得分:5)

您的所有表单信息都将在.cshtml文件中,如下所示:

@using (Html.BeginForm("Controller Action Method", "Controller Name", FormMethod.Post, new { id = "Form Name" }))
{
// Form Elements here
}

然后,您只需添加一个提交按钮,将表单提交给您的Controller进行处理。