HTML5 validation before ajax submit

前端 未结 6 1480
既然无缘
既然无缘 2020-12-01 01:38

This should be simple, yet it\'s driving me crazy. I have an html5 form that I am submitting with ajax. If you enter an invalid value, there is a popup response that tells y

相关标签:
6条回答
  • 2020-12-01 01:55

    If you bind to the submit event instead of click it will only fire if it passes the HTML5 validation.

    It is best practice to cache your jQuery selectors in variables if you use it multiple times so you don't have to navigate the DOM each time you access an element. jQuery also provides a .serialize() function that will handle the form data parsing for you.

    var $contactForm = $('#contactForm');
    
    $contactForm.on('submit', function(ev){
        ev.preventDefault();
    
        $.ajax({
            url: "scripts/mail.php",
            type:   'POST',
            data: $contactForm.serialize(),
            success: function(msg){
                disablePopupContact();
                $("#popupMessageSent").css("visibility", "visible");
            },
            error: function() {
                alert("Bad submit");
            }
        });
    });
    
    0 讨论(0)
  • 2020-12-01 01:55

    I prefer using the jQuery submit handler, you will still get the response to your form with the following method.

    jQuery('#contactForm').on('submit', function (e) {
        if (document.getElementById("contactForm").checkValidity()) {
            e.preventDefault();
            jQuery.ajax({
                url: '/some/url',
                method: 'POST',
                data: jQuery('#contactForm').serialize(),
                success: function (response) {
                    //do stuff with response
                }
            })
        }
        return true;
    });
    
    0 讨论(0)
  • 2020-12-01 02:01

    Not exactly sure what you mean. But I assume that you want to check in realtime if the input is valid. If so you should use .keyup instead of .click event, because this would lead to an action if the user presses submit. Look at http://api.jquery.com/keyup/

    With this you could check the input with every new character insert and display e.g. "not valid" until your validation ist true.

    I hope this answers your question!

    0 讨论(0)
  • 2020-12-01 02:06

    By default, jQuery doesn't know anything about the HTML5 validation, so you'd have to do something like:

    $('#submit').click(function(){
        if($("form")[0].checkValidity()) {
            //your form execution code
        }else console.log("invalid form");
    });
    
    0 讨论(0)
  • 2020-12-01 02:16

    U can also use jquery validate method to validate form like

    $("#form id").validate();

    which return boolean value based on form validation & also u can see the error in log using errorList method.

    for use above functionality u must include jquery.validate.js file in your script

    0 讨论(0)
  • 2020-12-01 02:21

    If you are using HTML5 form validation you'll have to send the ajax request in the form's submit handler. The submit handler will only trigger if the form validates. What you're using is a button click handler which will always trigger because it has no association with form validation. NOTE: not all browsers support html5 form validation.

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