資料載入中

我是 chung

鎖住記憶

  • Chung
  • 0°C
  • 8 年又 296 天

ajax防止重複提交

會發生重提交的原因,大致上是因為考驗人與系統間的耐性~

AJAX(非同步的JavaScript與XML技術)的好處是可以僅向伺服器傳送並取回必須的資料,並在用戶端採用JavaScript處理來自伺服器的回應。

所以大大減少web的負荷~取資料的速度也變快,因為只取要的資料顯示。

但是卻會遇到一個問題,當使用者透過AJAX傳送需求時,若是系統沒有提醒訊息~

或根本就是網路過慢來不及反應回答使用者的需求時~

使用者通常會沒耐性的多發送了不少次傳送訊息。

而這就會變成,AJAX的請求第一筆還未處理完就接著要處理第二筆第三筆.....最後....當了。

自己就常常遇到這樣的問題。

現在用下列的方式,試著解決這些問題。
page_requestLock = 0;//預設值為解鎖狀態
if(page_requestLock === 1){
return;
}else{
page_requestLock = 1
$.ajax({
async: false,
type: "POST",
url: "$URL",
data: dataString,
success : function(res){
$("#page_list").html(res);
page_requestLock = 0;
},
error: function(){
alert('載入錯誤!');
page_requestLock = 0;
}

})
}

首先先宣告了一個變數 page_requestLock 並將預設值設定為0

把他當作解鎖的狀態。

這樣,當AJAX執行時再將 page_requestLock 的值改變為1

鎖定的狀態。

直到完成訊息提交並顯示時,才又將狀態改回解鎖的狀態。

目前測試執行中~

以上紀錄。

台北市內湖區江南街71巷75弄 Go

  • AJAX技術在網頁應用中的優勢
  • 使用者耐性不足導致重提交問題
  • 解決AJAX請求重複發送的方法
  • 非同步資料傳輸對網站效能的影響
  • 如何有效管理AJAX請求的狀態鎖定
https://innstory.com/story-ajax防止重複提交-1276

上一篇
 網站植入Facebook登入FBapi請求修改

下一篇
走了一趟文具區這小天使是我小時候最常用的品牌鉛筆沒想到現在還有啊 

發表留言

作者簡介

我是chung,網路工作者

主業是網站系統開發建置
副業是做夢、紀錄故事
作品請參考:teme.biz
做夢請參考:innstory.com
聯絡:chung.teme@gmail.com

有人用筆寫日記,有人用歲月寫日記,有人用照片寫日記,而我,用innstory寫日記。


推薦閱讀

作者其他相關類別故事

JavaScript的獲取日期代碼不足兩位數補0

JavaScript的獲取日…

Chung 11 年又 137 天 2.8K

當我們用javascript得到了一個時間後...針對月份及日期的部分只會顯示數字... 但若我們需...

無障礙網頁accesskey

無障礙網頁accesskey

Chung 9 年又 294 天 1.9K

accesskey 無障礙網頁導盲磚。 是為了要方便有需求的人,可利用鍵盤即可快速瀏覽網頁切換網頁位...

賽馬

賽馬

Chung 2025-09-22 上午 9 點 229

別人的賽馬是看誰的馬跑的夠快。 你倒好,你這匹馬跑都不跑還直接給我躺平。 老師要你練習放鬆,但可...


推薦閱讀

這個地址也發生了其他故事

你是否知道我故事中的角色

你是否知道我故事中的角色

Chung 9 年又 80 天 1.9K

那天~突然在想....... 有看我故事的人,是否會知道我寫的那些故事裡,裏頭的人事物對我有何意義?...

innstory 更新故事分享功能植入

innstory 更新故事分…

Chung 9 年又 236 天 2.8K

Innstory 更新故事分享功能,花了點時間...但不得不說有時候我真的只是想分享一段文字或幾...

Android Studio 2.3 隨機改變背景顏色

Android Studio…

Chung 9 年又 17 天 3.5K

開始學習APP 其實我照著工具書上的方式總是在宣告變數時會產生問題~ 例如工具書上寫著可以直接拉...


附近景點

這個地址-台北市內湖區江南街71巷75弄-附近還有甚麼?

  • 北投普濟寺
  • 國立臺北護理健康大學城區部文教大樓
  • 臺北市政府舊廈(原建成小學校)
  • 臺灣總督府電話交換局
  • 西本願寺(鐘樓、樹心會館)
  • 陳德星堂