Asp.net mvc - Html Submit button not sent with post?

后端 未结 4 924
北海茫月
北海茫月 2020-12-20 13:50

As in the title. I use this method for allowing more than one submit button per form and more than one action to handle them.

However - for some odd reason - all of

相关标签:
4条回答
  • 2020-12-20 14:26

    Have you set the name on the input?

    Form fields don't get sent unless you specify the "name" attribute.

    <input type="submit" name="Delete" value="Delete" />
    <input type="submit" name="Edit" value="Delete" />
    

    EDIT: I see you're using buttons rather than submit. Which might be the problem.

    You need to have use inputs like this:

    <input  type="submit" value="Register" name="ActionRegister"/>
    <input  type="submit" value="Cancel" name="ActionCancel" class="cancel" />
    
    0 讨论(0)
  • 2020-12-20 14:30

    The way I have done this before is I post my form to same action. In my action I check the value of input button.

    So In your case you should do following on your View. Keep the name of both input submit same but different value.

    <% using (Html.BeginForm("SignUp", "SetUp", FormMethod.Post))
    {%>
    <%: Html.ValidationSummary()%>
         <input type="submit" value="Register" name="actionName" />
         <input  type="submit" value="Cancel" name="actionName" class="cancel">Cancel</input>
    }
    

    And on your controller

    public ActionResult SignUp_Register(SignUpViewModel vm,string actionName)
    {
        if(actionName =="Register")
              //Do something;
        if(actionName =="Cancel")
              //Do something;
    
        return View();
    }
    

    In standard cases these should work....

    Let me highlight something interesting now...!!

    1)On Submit event of the form if you are disabling all input type of submit in your JavaScript to disable double submit, then you will always get null values for them in the controller as they are disabled.

    2)I realized that you have cancel class on your submit which has some unintended behavior if you are using jQuery validation. Ref: http://docs.jquery.com/Plugins/Validation/Reference

    Hope this helps..!!

    0 讨论(0)
  • 2020-12-20 14:32

    You need to set equal the id of the button (View) and the name of the variable to receive (Controller) The value of the button will be sent to the variable

        <button type="submit" id="btnRegister" name="btn" class="btn btn-primary" value="Register">
            Register
        </button>
        <button type="submit" id="btnCancel" name="btn" class="btn btn-primary" value="Cancel">
            Cancel
        </button>
    

    And your controller:

        [HttpPost]
        public ActionResult SignUp_Register(string btn, SignUpViewModel vm m)
    

    variable btn will be either "Register" or "Save" depending on the button clicked

    0 讨论(0)
  • 2020-12-20 14:43

    This:

    <button  type="submit" value="Register" name="ActionRegister" >Register</button>
    <button  type="submit" value="Cancel" name="ActionCancel" class="cancel" >Cancel</button>
    

    Seems to work?! wtf?

    0 讨论(0)
提交回复
热议问题