js控制再次點擊按鈕之間的間隔時間可防止重複提交,js間隔時間

來源:互聯網
上載者:User

js控制再次點擊按鈕之間的間隔時間可防止重複提交,js間隔時間

<script type="text/javascript" language="javascript"> var wait = 60; function change() { $o = $("#J_refresh_checkcode"); if(wait == 0) { $o.removeAttr("disabled"); $o.html("看不清?換一張"); wait = 60; } else { $o.attr("disabled", true); $o.attr("font-color", "gray"); $o.html(wait + "秒後可重新擷取"); wait--; if(wait == 59) { var imgNode = document.getElementById("vimg"); imgNode.src = "../../AjaxServer/CheckCodePic.ashx?t=" + (new Date()).valueOf(); // 這裡加個時間的參數是為了防止瀏覽器緩衝的問題 $("#J_checkcode_tip").addClass("hide"); $("#J_checkcode_tip>div").html(""); $("#<%=hidPicMessage.ClientID%>").val(""); } setTimeout(function() { change() }, 1000) } }</script>

則 html如下:

<div class="kv_item clear"> <span class="kv_label fl">驗證碼</span> <input name="checkCode" class="i_textshort fl" id="J_checkcode_input" onmousedown="ClearCodeMessage()" type="text" maxlength="6" autocomplete="off" onblur="CheckCode()" /> <img src="../../AjaxServer/CheckCodePic.ashx" height="28" id="vimg" alt="" style="float:left;margin:-1px 0 0 3px"/> <a id="J_refresh_checkcode" onclick="change()">看不清,換一張</a> <div class="msg msg-inline msg-weak hide" id="J_checkcode_tip"> <div class="msg-default msg-error"> <i class="msg-icon"></i> <div class="msg-content"> </div> </div> </div> </div>

30秒內禁止重複提交button按鈕

提交的圖片應該調用一個js function,
然後在function中submit()表單,
這樣你就可以在你的js中定義一個變數(boolean)

var submited=false;
function submitform(){
if(!submited){
submitted=true;
document.formname.submit();
//這裡再設個定時器,30秒後把submitted的值再改成false;
}else{
alert('30秒內不能提交');
}
}
 
js 怎防止 重新整理重複提交

使用Session

在提交的頁面也就是資料庫處理之前:

if session("ok")=true then
response.write "錯誤,正在提交"
response.end
end if

資料處理完後,修改session("ok")=false。

資料處理成功馬上Redirect到另外一個頁面

操作後重新整理的確是個問題,你可以使用跳轉頁面、關閉本頁面,如果是有參資料條件來控制的,那就應該好做了,可以直接修改window.location的值,把參數全部改掉,這樣就差不多了。

缺點:簡單地運用Response.Redirect將不再有效,因為使用者從一個頁面轉到另一個頁面,我們都必須用用戶端代碼清除location.history。注意,這種方法清除的是最後一個訪問記錄,而不是全部的訪問記錄。 點擊後退按鈕,再點擊後退按鈕,你可以看到這時開啟的是本頁面之前的頁面!(當然,這是在你的用戶端啟用了javascript功能的條件下。)
 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.