asp.net-mvc-3 – 一个窗体中的多个提交输入

前端之家收集整理的这篇文章主要介绍了asp.net-mvc-3 – 一个窗体中的多个提交输入前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我目前遇到与多个操作按钮处于同一形式的问题。

第一个按钮将执行验证,而第二个按钮将保存配置文件。第三个将简单地将用户重定向页面之外,但是仍然需要通过控制器进行一些追踪。最后一个按钮是删除。因为它们被放在一起,我需要通过POST传递ModelBinding,所以不可能把它们分成多种形式。

目前,为了区分哪个动作被点击,我有一个隐藏的输入在我的窗体和onclick,javascript将更新隐藏的输入,以便它将被传回给控制器。

我这样做的原因是因为一些奇怪的原因,FormCollection不想保留我的提交值。我试图通过控制器访问按钮

formCollection["verify"]

但事实证明是空的。输入提交的id和name都设置为验证。

我也尝试了许多其他建议,如thisthis,但没有效果。是否有更好的方法解决我的问题,而不使用javascript来改变隐藏的输入?

解决方法

最好的方法是单独处理不同按钮的动作,如 this article所述。

如果你想要一个丑陋的动作做所有的东西,那么你可以给你的提交按钮名称

@using (Html.BeginForm())
{
    ... input fields for the model

    <button type="submit" name="btn" value="verify">Verify data</button>
    <button type="submit" name="btn" value="save">Save data</button>  
    <button type="submit" name="btn" value="redirect">Redirect</button>
}

你不需要任何隐藏的字段或javascript。然后在您的控制器操作中,您将检查btn参数的值(这显然将是您查看模型的一部分):

[HttpPost]
public ActionResult Foo(MyViewsModel model)
{
    if (model.Btn == "verify")
    {
        // the Verify button was clicked
    }
    else if (model.Btn == "save")
    {
        // the Save button was clicked
    } 
    else if (model.Btn == "redirect")
    {
        // the Redirect button was clicked
    } 
    else
    {
        // ??? throw
    }

    ...
}

当然,如果您遵循我的建议并分开您的操作(如文章中所述):

@using (Html.BeginForm("Action","Home"))
{
    ... input fields for the model

    <input type="submit" name="verify" value="Verify data" />
    <input type="submit" name="save" value="Save data" />
    <input type="submit" name="redirect" value="Redirect" />
}

接着:

[HttpParamAction]
[HttpPost]
public ActionResult Verify(Myviewmodel model)
{
    ...
}

[HttpParamAction]
[HttpPost]
public ActionResult Save(Myviewmodel model)
{
    ...
}

[HttpParamAction]
[HttpPost]
public ActionResult Redirect(Myviewmodel model)
{
    ...
}

这是一个更干净的代码,不违反单一责任原则。

猜你在找的asp.Net相关文章