这在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中似乎没有错误。
由于 海梅
答案 0 :(得分:0)
旧的IE版本有event.returnValue = false
试试这个以支持IE和其他浏览器:
event.preventDefault ? event.preventDefault() : event.returnValue = false;