检查onsubmit doenst work jquery contactform上的函数

Check functions on onsubmit doenst work jquery contactform

本文关键字:函数 contactform jquery onsubmit doenst work 检查      更新时间:2023-09-26

更新。。

代码现在工作

必须更改表单提交中的验证声明。删除了有效的vars等,但它现在工作感谢

固定提交给

$('form').on("submit", function(e) {
            //Prevent default
            e.preventDefault();
                    if(validateName() & validateSubject() & validateEmail() & validateMessage())
                    {
                        $('form #status').removeClass().addClass('processing').html('Processing...').fadeIn('fast');
                        // maak variable met alle data die verstuurd kan worden
                        var formData = $('form').serialize();
                        //functie om data naar server te sturen
                        submitForm(formData);
                        return true;
                    }
                    else
                    {
                        $('form #status').removeClass().addClass('error')
                            .html('<strong>Form is not filled in correctly</strong>').fadeIn('fast')
                        return false;
                    }
            });

您的问题是您没有阻止表单的提交。相反,您会挂接"提交"按钮,然后在出现问题时只显示一条错误消息(但表单仍然会被提交,因此错误消息没有帮助)。

你可以/应该做几件事来解决这个问题。首先,您可能希望将验证代码附加到表单的提交事件(而不是提交按钮的单击事件)。这将确保,如果您将来提供其他提交表单的方法,则不需要单独维护每个方法上的验证挂钩。所以不是:

$('form #submit').click(function(e) {

你可能想要:

$('form').on("submit", function(e) {

其次,如果表单出现问题,则需要在提交处理程序中返回false。这将导致一个隐含的e.preventDefault(),它将阻止表单提交:

if (valid != '') {
    $('form #status').removeClass().addClass('error')
        .html('<strong>Correct these errors<BR></strong>' + valid).fadeIn('fast');
    return false; //stop form submission
    //Or you could do e.preventDefault(); if you're not ready to end the function yet.
}

这应该能解决你最紧迫的问题。坚持下去!