Is there a better jQuery solution to this.form.submit();?

前端 未结 8 451
醉梦人生
醉梦人生 2020-12-02 20:13

I want to trigger the submit event of the form the current element is in. A method I know works sometimes is:

this.form.submit();

I\'m wond

相关标签:
8条回答
  • 2020-12-02 20:30

    In JQuery you can call

    $("form:first").trigger("submit")
    

    Don't know if that is much better. I think form.submit(); is pretty universal.

    0 讨论(0)
  • 2020-12-02 20:31

    You can always JQuery-ize your form.submit, but it may just call the same thing:

    $("form").submit(); // probably able to affect multiple forms (good or bad)
    
    // or you can address it by ID
    $("#yourFormId").submit();
    

    You can also attach functions to the submit event, but that is a different concept.

    0 讨论(0)
  • 2020-12-02 20:35

    I have found that using jQuery the best solution is

    $(this.form).submit()
    

    Using this statement jquery plugins (e.g. jquery form plugin) works correctly and jquery DOM traversing overhead is minimized.

    0 讨论(0)
  • 2020-12-02 20:36
    <form method="get">
       <p><label>Field Label
          <select onchange="this.form.submit();">
             <option value="blah">Blah</option>
                ....
         </select>
         </label>
       </p>
        **<!-- <input name="submit" type="submit" /> // name="submit_new_name" -->**
      </form>
    
    <!-- 
    
       this.form.submit == this.form.elements['submit'];
    
    -->
    
    0 讨论(0)
  • 2020-12-02 20:38
    this.form.submit();
    

    This is probably your best bet. Especially if you are not already using jQuery in your project, there is no need to add it (or any other JS library) just for this purpose.

    0 讨论(0)
  • 2020-12-02 20:39

    I think what you are looking for is something like this:

    $(field).closest("form").submit();
    

    For example, to handle the onchange event, you would have this:

    $(select your fields here).change(function() {
        $(this).closest("form").submit();
    });
    

    If, for some reason you aren't using jQuery 1.3 or above, you can call parents instead of closest.

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