asp.Net   发布时间:2022-04-07  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了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-mvc-3 – 一个窗体中的多个提交输入全部内容,希望文章能够帮你解决asp.net-mvc-3 – 一个窗体中的多个提交输入所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。