已按下提交按钮的MVC

时间:2009-11-11 09:22:09

标签: c# asp.net asp.net-mvc razor

我的MVC表单上有两个按钮:

<input name="submit" type="submit" id="submit" value="Save" />
<input name="process" type="submit" id="process" value="Process" />

从我的Controller动作中我如何知道哪一个被按下了?

11 个答案:

答案 0 :(得分:160)

将您的提交按钮命名为相同

<input name="submit" type="submit" id="submit" value="Save" />
<input name="submit" type="submit" id="process" value="Process" />

然后在你的控制器中获取提交的值。只有点击的按钮才会传递其值。

public ActionResult Index(string submit)
{
    Response.Write(submit);
    return View();
}

您当然可以评估该值以使用开关块执行不同的操作。

public ActionResult Index(string submit)
{
    switch (submit)
    {
        case "Save":
            // Do something
            break;
        case "Process":
            // Do something
            break;
        default:
            throw new Exception();
            break;
    }

    return View();
}

答案 1 :(得分:47)

<input name="submit" type="submit" id="submit" value="Save" />
<input name="process" type="submit" id="process" value="Process" />

在你的控制器动作中:

public ActionResult SomeAction(string submit)
{
    if (!string.IsNullOrEmpty(submit))
    {
        // Save was pressed
    }
    else
    {
        // Process was pressed
    }
}

答案 2 :(得分:33)

这是一个更好的答案,因此我们可以为按钮提供文本和值:

http://weblogs.asp.net/dfindley/archive/2009/05/31/asp-net-mvc-multiple-buttons-in-the-same-form.aspx

</p>
<button name="button" value="register">Register</button>
<button name="button" value="cancel">Cancel</button>
</p>

和控制器:

public ActionResult Register(string button, string userName, string email, string password, string confirmPassword)
{
if (button == "cancel")
    return RedirectToAction("Index", "Home");
...

简而言之,它是一个SUBMIT按钮,但你选择使用name属性的名称,它更强大,因为你没有义务提交控制器方法参数中的名称或按钮,你可以随意调用它...... / p>

答案 3 :(得分:18)

您可以从下面的名称标签中识别您的按钮, 您需要在控制器中进行检查

if (Request.Form["submit"] != null)
{
//Write your code here
}
else if (Request.Form["process"] != null)
{
//Write your code here
}

答案 4 :(得分:5)

这是一个非常好用且简单的方法,使用自定义MultiButtonAttribute非常容易理解:

http://blog.maartenballiauw.be/post/2009/11/26/Supporting-multiple-submit-buttons-on-an-ASPNET-MVC-view.aspx

总结一下,按照以下步骤制作提交按钮:

<input type="submit" value="Cancel" name="action" />
<input type="submit" value="Create" name="action" /> 

你的行为是这样的:

[HttpPost]
[MultiButton(MatchFormKey="action", MatchFormValue="Cancel")]
public ActionResult Cancel()
{
    return Content("Cancel clicked");
}

[HttpPost]
[MultiButton(MatchFormKey = "action", MatchFormValue = "Create")]
public ActionResult Create(Person person)
{
    return Content("Create clicked");
} 

创建这个类:

[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
public class MultiButtonAttribute : ActionNameSelectorAttribute
{
    public string MatchFormKey { get; set; }
    public string MatchFormValue { get; set; }

    public override bool IsValidName(ControllerContext controllerContext, string actionName, MethodInfo methodInfo)
    {
        return controllerContext.HttpContext.Request[MatchFormKey] != null &&
            controllerContext.HttpContext.Request[MatchFormKey] == MatchFormValue;
    }
}

答案 5 :(得分:3)

// Buttons
<input name="submit" type="submit" id="submit" value="Save" />
<input name="process" type="submit" id="process" value="Process" />

// Controller
[HttpPost]
public ActionResult index(FormCollection collection)
{
    string submitType = "unknown";

    if(collection["submit"] != null)
    {
        submitType = "submit";
    }
    else if (collection["process"] != null)
    {
        submitType = "process";
    }

} // End of the index method

答案 6 :(得分:2)

这篇文章不会回答Coppermill,因为他很久以前就得到了回答。我的帖子将有助于谁将寻求这样的解决方案。首先,我不得不说“WDuffy的解决方案是完全正确的”并且它工作正常,但我的解决方案(实际上不是我的)将用于其他元素,它使表示层更加独立于控制器(因为你的控制器依赖于“value”用于显示按钮的标签,此功能对其他语言很重要。)。

这是我的解决方案,给他们不同的名字:

<input type="submit" name="buttonSave" value="Save"/>
<input type="submit" name="buttonProcess" value="Process"/>
<input type="submit" name="buttonCancel" value="Cancel"/>

您必须在下面的操作中将按钮的名称指定为参数:

public ActionResult Register(string buttonSave, string buttonProcess, string buttonCancel)
{
    if (buttonSave!= null)
    {
        //save is pressed
    }
    if (buttonProcess!= null)
    {
        //Process is pressed
    }
    if (buttonCancel!= null)
    {
        //Cancel is pressed
    }
}

当用户使用其中一个按钮提交页面时,只有一个参数具有值。我想这会对其他人有所帮助。

<强>更新

这个答案很老,我实际上是在重新考虑我的观点。也许上面的解决方案适用于将参数传递给模型属性的情况。不要打扰自己,为你的项目采取最佳解决方案。

答案 7 :(得分:2)

为了方便起见,我会说您可以将按钮更改为以下内容:

<input name="btnSubmit" type="submit" value="Save" />
<input name="btnProcess" type="submit" value="Process" />

你的控制器:

public ActionResult Create(string btnSubmit, string btnProcess)
{
    if(btnSubmit != null)
       // do something for the Button btnSubmit
    else 
       // do something for the Button btnProcess
}

答案 8 :(得分:1)

为两个按钮命名,并从表单中检查值。

<div>
   <input name="submitButton" type="submit" value="Register" />
</div>

<div>
   <input name="cancelButton" type="submit" value="Cancel" />
</div>

在控制器端:

public ActionResult Save(FormCollection form)
{
 if (this.httpContext.Request.Form["cancelButton"] !=null)
 {
   // return to the action;
 }

else if(this.httpContext.Request.Form["submitButton"] !=null)
 {
   // save the oprtation and retrun to the action;
 }
}

答案 9 :(得分:1)

在Core 2.2 Razor页面中,此语法有效:

    <button type="submit" name="Submit">Save</button>
    <button type="submit" name="Cancel">Cancel</button>
public async Task<IActionResult> OnPostAsync()
{
    if (!ModelState.IsValid)
        return Page();
    var sub = Request.Form["Submit"];
    var can = Request.Form["Cancel"];
    if (sub.Count > 0)
       {
       .......

答案 10 :(得分:0)

你能不能找到使用Request.Form Collection?如果单击了process,则request.form [“process”]将不为空