Asp.Net MVC 3 表单集合在提交后丢失数据

Asp.Net MVC 3 formcollection losing data after submit

本文关键字:提交 数据 集合 Net MVC 表单 Asp      更新时间:2023-09-26

我有一个 Asp.Net 的MVC 3应用程序,在我单击提交按钮后,我想验证在formcollection参数中传递的信息..如果它无效,我返回一个jSon..但在那之后,我的表单集合总是返回null

这发生在Chrome和FFox中。 在IE中它工作正常

我的观点:

<li id="opc-register" class="section allow">
    <div id="checkout-step-register" class="step a-item" style="display: none;">
        <form id="co-register-form" action="">
        <div id="checkout-register-load">
            @Html.Action("OpcRegisterForm", "Checkout")
        </div>
        </form>
        <script type="text/javascript">
            Register.init('#co-register-form', '@(storeLocation)checkout/OpcSaveRegister/'); 
        </script>
        <div class="buttons" id="register-buttons-container">                           
            <button type="button" class="paymentmethodnextstepbutton" onclick="Register.save()">
                <span>@T("Common.Continue")</span>
            </button>
            <span class="please-wait" id="register-please-wait" style="display: none;">
                <img src="@Url.Content("~/Content/Images/ajax_loader_small.gif")"
    alt="@T("Common.LoadingNextStep")" title="@T("Common.LoadingNextStep")" />
                @T("Common.LoadingNextStep")</span>
        </div>
    </div>
</li>

我的控制器

[HttpPost]
public ActionResult OpcSaveRegister(FormCollection form)
{
    var registerModel = PrepareRegisterModel();
    registerModel.Email = form["Email"];
    registerModel.FirstName = form["FirstName"];
    ...
    if (TryValidateModel(registerModel))
    {
       ....
    }
    //If we got this far, something failed, redisplay form
    return Json(new
    {
        update_section = new UpdateSectionJsonModel()
        {
            name = "register",
            html = RenderPartialViewToString("OpcRegister", registerModel)
        },
        goto_section = "register"
    });
}

不要在带有 MVC 的帖子上使用 FormCollection。使用强类型 ViewModel,其中包含可在帖子表单中提交的所有属性。

例如,你可以有一个这样的类:

public class RegisterViewModel
{
    public string FirstName { get; set; }
    public string Email { get; set; }
    //...
}

在您看来,您可以使用以下命令设置这些属性:

@Html.EditorFor(m => m.FirstName)
@Html.EditorFor(m => m.Email)

然后对于您的操作,您将拥有

[HttpPost]
public ActionResult OpcSaveRegister(RegisterViewModel registerModel)
{
    //...
}