按钮的Ajax请求时一次点击两次提交的解决方法
页面中的按钮的type是submit的:<inputtype="submit"value="Create"id="submit"/>
ajax的请求,在JQuery中是:
$(function(){
$('#submit').click(function(){
varcreateGenreForm=$('#createGenreForm');
if(createGenreForm.valid()){
varobj={
Name:$('#Name').val(),
Description:$('#Description').val()
};
varjsonSerialized=JSON.stringify(obj);
$.ajax({
type:"POST",
url:createGenreForm.attr('action'),
dataType:"json",
contentType:"application/json;charset=utf-8",
data:jsonSerialized,
success:function(result){
alert(result.Message);
},
error:function(error){
alert("Therewasanerrorpostingthedatatotheserver:"+error.responseText);
}
});
}
});
});
发生两次提交的原因是在执行完ajax请求后,并没有阻止submit的行为,所以解决方法有两种:
1、不使用type为submit类型的按钮,而是使用type是button的按钮。
2、在$('#submit').click函数中,最后加一行returnfalse;,即可阻止submit。
一点说明:为什么在标题中要嵌入英文?原因是为了能够让国外的网友能查询到这篇文章。平常在Google上查资料的时候,经常参考国外网友的博客,帮助我解决了很多问题,所以我也想让他们能够参考我写的内容。当然文中我不可能全部译为英文,所以我尽量把代码粘全,靠代码说话吧。
以上所述是小编给大家介绍的按钮的Ajax请求时一次点击两次提交的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!