頁(yè)面中的按鈕的type是submit的: input type="submit" value="Create" id="submit" />
ajax的請(qǐng)求,在JQuery中是:
$(function () {
$('#submit').click(function () {
var createGenreForm = $('#createGenreForm');
if (createGenreForm.valid()) {
var obj = {
Name: $('#Name').val(),
Description: $('#Description').val()
};
var jsonSerialized = 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("There was an error posting the data to the server: " + error.responseText);
}
});
}
});
});
發(fā)生兩次提交的原因是在執(zhí)行完ajax請(qǐng)求后,并沒(méi)有阻止submit的行為,所以解決方法有兩種:
1、不使用type為submit類(lèi)型的按鈕,而是使用type是button的按鈕。
2、在$('#submit').click函數(shù)中,最后加一行return false;,即可阻止submit。
一點(diǎn)說(shuō)明:為什么在標(biāo)題中要嵌入英文?原因是為了能夠讓國(guó)外的網(wǎng)友能查詢(xún)到這篇文章。平常在Google上查資料的時(shí)候,經(jīng)常參考國(guó)外網(wǎng)友的博客,幫助我解決了很多問(wèn)題,所以我也想讓他們能夠參考我寫(xiě)的內(nèi)容。當(dāng)然文中我不可能全部譯為英文,所以我盡量把代碼粘全,靠代碼說(shuō)話吧。
以上所述是小編給大家介紹的按鈕的Ajax請(qǐng)求時(shí)一次點(diǎn)擊兩次提交的解決方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
您可能感興趣的文章:- JS Ajax請(qǐng)求如何防止重復(fù)提交
- .NET的Ajax請(qǐng)求數(shù)據(jù)提交實(shí)例
- AJAX避免用戶(hù)重復(fù)提交請(qǐng)求實(shí)現(xiàn)方案
- Ajax異步(請(qǐng)求)提交類(lèi) 支持跨域