按钮的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请求时一次点击两次提交的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!