将提交事件附加到表单时,表单将使用默认处理程序

时间:2017-04-28 22:31:24

标签: javascript jquery html ajax forms

这在IE和Firefox中发生。不是铬。

我有这样的表格:

        <form id="enviaEmail" method="post">
            <label for="nombre">Nombre</label>
            <input id="nombre" type="text" name="nombre" required="" />

            <label for="apellido">Apellido</label>
            <input id="apellido" type="text" name="apellido" required="" />

            <label for="email">E-mail</label>
            <input id="email" type="email" name="email"  required="" />

            <label for="telefono">Teléfono</label>
            <input id="telefono" type="text" name="telefono" />

            <label for="mensaje">Comentarios</label>
            <textarea id="mensaje" name="mensaje" required="" ></textarea>

            <input id="submit" type="submit" name="submit" value="Enviar" />
        </form> 

这个javascrpt附加了我自己的事件,通过Ajax发布帖子:

(function ($) {
    $(document).ready(function () {
        // ação que oculta a mensagem ao clicar no x
        $(".close").on('click', function () {
            $(this).parent().fadeOut();
        })
        // REQUISIÇÃO AJAX ENVIO DE E-MAIL
        $("#enviaEmail").on("submit", function (event) {
            event.preventDefault();

            // pega todos inputs
            var value = $(this).serializeArray(),
                    // objeto de dados para requisição
                    request = {
                        'option': 'com_ajax',
                        'module': 'wgajaxcontato',
                        'data': value,
                        'format': 'jsonp'
                    };

            // requisição ajax
            $.ajax({
                type: 'POST',
                data: request,
                beforeSend: function () {
                    $('.hum_form_contact .formulario .loading').fadeIn().css('display', 'table');
                    $("#enviaEmail #submit").attr("disabled", true);
                },
                success: function (resposta) {
                    $("#resposta").fadeIn().html(resposta).delay(5000);
                    //$("#resposta").fadeIn().html(resposta).delay(5000).fadeOut(500);
                },
                complete: function () {
                    $(".hum_form_contact .formulario .loading").fadeOut().css('display', 'none');
                    $("#enviaEmail #submit").attr("disabled", false);
                    $("#nombre").val("");
                    $("#apellido").val("");
                    $("#email").val("");
                    $("#assunto").val("");
                    $("#telefono").val("");
                    $("#mensaje").val("");
                    $("#sccaptcha").val("");
                }
            });
        });
    });
})(jQuery);

问题是在chrome中,所有作品都很完美。也就是说,我填写表格然后当我按下&#34;提交&#34;按钮,表单使用我的自定义事件处理程序中的代码发送帖子。

在Firefox或IE中,当我按下提交按钮时,表单将使用默认处理程序提交,因此将重新加载整个页面。我可以意识到这一点,因为如果我在我的处理程序中放置一个警报,它就不会显示。

这里有什么问题?

控制台中没有显示任何错误,因此HTML或Javascript中似乎没有错误。

由于 海梅

1 个答案:

答案 0 :(得分:0)

旧的IE版本有event.returnValue = false 试试这个以支持IE和其他浏览器: event.preventDefault ? event.preventDefault() : event.returnValue = false;

IE Legacy event properties