主頁 > 知識(shí)庫 > asp.net表單提交時(shí)防重復(fù)提交并執(zhí)行前臺(tái)的JS驗(yàn)證

asp.net表單提交時(shí)防重復(fù)提交并執(zhí)行前臺(tái)的JS驗(yàn)證

熱門標(biāo)簽:辦理400電話證件 外呼系統(tǒng)費(fèi)用一年 十堰正規(guī)電銷機(jī)器人系統(tǒng) 怎么給超市做地圖標(biāo)注入駐店 寧波自動(dòng)外呼系統(tǒng)代理 巫師3為什么地圖標(biāo)注的財(cái)寶沒有 手機(jī)地圖標(biāo)注如何刪除 世紀(jì)佳緣地圖標(biāo)注怎么去掉 外呼系統(tǒng)代理品牌
在項(xiàng)目開發(fā)中,遇到這樣的一個(gè)情況,就是用戶重復(fù)提交。當(dāng)然這個(gè)不能怪用戶,只能怪.NET或者服務(wù)器反應(yīng)遲鈍......我是這樣理解的。
在網(wǎng)上搜了一下,解決方案是不少,比如:
http://bbs.csdn.net/topics/340048988
(這個(gè)大家提了不少建議)
http://www.cnblogs.com/blsong/archive/2009/12/24/1631144.html
(這個(gè)基本上總結(jié)了網(wǎng)上的方法)
但實(shí)際上做互聯(lián)網(wǎng)web項(xiàng)目中,需要在前臺(tái)執(zhí)行JS或者Jquery的驗(yàn)證(主要是增強(qiáng)用戶體驗(yàn)),那么再使用上面的方法,就會(huì)出現(xiàn)問題。要么重復(fù)提交依然存在,要么前臺(tái)JS驗(yàn)證失效。最后沒辦法,只有自己寫一個(gè),在滿足阻止用戶重復(fù)提交的情況下,還能保證前臺(tái)JS驗(yàn)證有效。代碼如下:
復(fù)制代碼 代碼如下:

//按鈕注冊(cè)加載樣式事件
var ItSelfButton;
var ControlRegPostResult = true;
function AddInputClick() {
$("input[type='submit']").click(function () {
ItSelfButton = $(this);
if (ItSelfButton.attr("repeat") == null) {
var btnDiv = $("div>");
btnDiv.attr("id", "Mask_BTN");
var divimg = $("img>");
divimg.attr("alt", "加載中...");
divimg.attr("src", "/Images/ButtonLoading.gif");
divimg.css({ "margin-left": ($(this).width() - 4) / 2, "margin-top": ($(this).height() - 16) / 2 });
btnDiv.append(divimg);
btnDiv.css({ width: $(this).width() + 12 + "px", height: $(this).height() + "px", top: $(this).offset().top + "px", left: $(this).offset().left + "px", position: "absolute" });
$(document.body).append(btnDiv);
setTimeout(MaskTimeOutRemove, 200);
}
});
}
$(function () {
AddInputClick();
});
$(window).resize(function () {
if (ItSelfButton != null) {
$("#Mask_BTN").css({ top: ItSelfButton.offset().top + "px", left: ItSelfButton.offset().left + "px" });
}
});
function MaskRemove() {
$("#Mask_BTN").remove();
}
function MaskTimeOutRemove() {
if (!ControlRegPostResult) {
$("#Mask_BTN").remove();
ControlRegPostResult = true;
}
}

其中在JS 驗(yàn)證失敗中將
復(fù)制代碼 代碼如下:

ControlRegPostResult = false;

這樣基本上滿足我的目的了。
ButtonLoading.gif 可以是一個(gè)打轉(zhuǎn)的圖片 ,也可以和按鈕一樣大。反正目的是這個(gè)層把按鈕遮住。
您可能感興趣的文章:
  • Jquery+asp.net后臺(tái)數(shù)據(jù)傳到前臺(tái)js進(jìn)行解析的方法
  • asp.net后臺(tái)cs中的JSON格式變量在前臺(tái)Js中調(diào)用方法(前后臺(tái)示例代碼)
  • ASP.NET 前臺(tái)javascript與后臺(tái)代碼調(diào)用
  • 淺談AjaxPro.dll,asp.net 前臺(tái)js調(diào)用后臺(tái)方法

標(biāo)簽:通遼 嘉興 景德鎮(zhèn) 山西 泰州 牡丹江 天門

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net表單提交時(shí)防重復(fù)提交并執(zhí)行前臺(tái)的JS驗(yàn)證》,本文關(guān)鍵詞  asp.net,表單,提交,時(shí)防,重復(fù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《asp.net表單提交時(shí)防重復(fù)提交并執(zhí)行前臺(tái)的JS驗(yàn)證》相關(guān)的同類信息!
  • 本頁收集關(guān)于asp.net表單提交時(shí)防重復(fù)提交并執(zhí)行前臺(tái)的JS驗(yàn)證的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章