大佬教程收集整理的这篇文章主要介绍了asp.net-mvc-3 – 一个窗体中的多个提交输入,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
第一个按钮将执行验证,而第二个按钮将保存配置文件。第三个将简单地将用户重定向到页面之外,但是仍然需要通过控制器进行一些追踪。最后一个按钮是删除。因为它们被放在一起,我需要通过POST传递ModelBinding,所以不可能把它们分成多种形式。
目前,为了区分哪个动作被点击,我有一个隐藏的输入在我的窗体和onclick,javascript将更新隐藏的输入,以便它将被传回给控制器。
我这样做的原因是因为一些奇怪的原因,FormCollection不想保留我的提交值。我试图通过控制器访问按钮
formCollection["verify"]
但事实证明是空的。输入提交的id和name都设置为验证。
我也尝试了许多其他建议,如this和this,但没有效果。是否有更好的方法来解决我的问题,而不使用javascript来改变隐藏的输入?
如果你想要一个丑陋的动作做所有的东西,那么你可以给你的提交按钮名称:
@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,请注明来意。