中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

前端防止用戶重復提交js實現代碼示例

發布時間:2020-09-14 01:48:17 來源:腳本之家 閱讀:179 作者:小黎也 欄目:web開發

背景

前端在向后端進行數據提交的時候,通常會需要在第一次提交返回前,阻止用戶在快速點擊發送二次請求,即防止重復提交,最簡單的方法是使用標志參數或者 class 元素控制,但缺點是,每個控制重復提交的地方都需要加上這個邏輯,重復性太強,且控制邏輯不統一。

目前前端使用的是http協議,所以提交方式為兩種

  • 異步提交,使用jQuery.ajax()
  • form 表單同步提交

下面這篇文章將給大家詳細介紹關于這兩種方法實現的方法示例,下面話不多說了,來隨著小編一起看看詳細的介紹吧

異步防重復提交的方案如下

通過 jQuery 提供的 ajaxPrefilter 方法,將在請求提交之前進行過濾,僅保留第一次請求,后續的請求 abort 阻止掉,具體實現代碼如下

/**
 * _pendingRequests = {
 * 'http:xxx.xxxx.do':['domain=P2P','xxxx=aaa'],
 * 'http:xxx.yyyy.do':['domain=P3P','xxxx=bbb']
 * }
 * 該對象的 key 是請求的 url ,value 是由請求參數轉化成的字符串數組
 */
var _pendingRequests = {};
$.ajaxPrefilter(function(options, originalOptions, jqXHR) {
 var p_item = { //保存請求請求的url
 key:options.url,
 index:0
 },
 dataArray = options.data ? options.data.split('&') : [];
 compareData = function(beforD,afterD) {
 //當url相同時,以此比較保存的參數對象,若參數對象相同,則返回false,若第一個就相同,則跳出循環
 // 反之說明當前參數對象列表中沒有與將要提交的參數相同,則可看為不同的請求,返回true,允許發起請求
 var result = false;
 for(var i=0;i<beforD.length;i++){
 if(beforD[i]){
  result = false;
  var beforData = beforD[i];
  for(var j=0;j<beforData.length;j++){
  if(afterD[j] !== beforData[j]){
  result = true;
  break;
  }
  }
  if (!result){
  break;
  }
 }else {
  result = true;
  continue;
 }
 }
 return result;
 };

 //若請求隊列中不存在或者同一個請求不同參數,且不為html后綴,則加入隊列中
 if (( !_pendingRequests[p_item.key] || compareData(_pendingRequests[p_item.key],dataArray) ) && p_item.key.indexOf('.html') === -1) {
 //給 index 賦值是因為請求是異步返回的,index用于標記第一個請求
 if(_pendingRequests[p_item.key]){
 p_item.index = _pendingRequests[p_item.key].push(dataArray)-1;
 } else{
 _pendingRequests[p_item.key] = [dataArray];
 p_item.index = 0;
 }
 } else if (p_item.key.indexOf('.html') === -1) {
 jqXHR.abort(); // 放棄后觸發的重復提交,僅保留第一次提交
 //pendingRequests[key].abort(); // 放棄先觸發的提交
 }
 var complete = options.complete;
 //請求完成
 options.complete = function(jqXHR, textStatus) {
 // 通過 key 和 index 獲取成功返回的請求,將其值為 null ,下一次該請求便是在請求隊列中便是新的一個請求
 _pendingRequests[p_item.key][p_item.index] = null;
 if ($.isFunction(complete)) {
 complete.apply(this, arguments);
 }
 };
});

jquery.ajaxprefilter官方文檔

表單提交防重復提交的方案如下

表單的處理就稍微要麻煩點,但大致思路和異步的相同,等待第一次請求返回的同時,阻止后續觸發的請求發送
首先基于jquery擴展了一個自定義的方法,如下

$.fn.preventDoubleSubmission = function() {
 $(this).on('submit', function(e) {
 var $form = $(this);
 // $form.data('submitted') 通過該變量判斷請求的狀態
 if ($form.data('submitted') === true) {
 //阻止請求
 e.preventDefault();
 } else {
 $form.data('submitted', true);
 if ($form.attr('target') === '_blank') {
 setTimeout(function() {
  $form.data('submitted', false);
 }, 800);
 }
 }
 });
 return this;
};

當表單初次提交時,通過 jQuery.data() 設置一個標志位,當表單重復提交時,判斷設置的標志位,若是提交狀態,將阻止表單的提交事件。當form.target = _blank 提交后打開新界面的情況,將在800毫秒后恢復原界面表單可提交狀態。

為了方便對全站的表單提交統一處理,可對需要放重復提交的表單添加一個class preventDouble,在頁面渲染后,統一加上事件監聽

//掃描帶有 preventDouble 標識的form表單
$(function() {
 var f = $('.contain form.preventDouble');
 for (var i=0;i<f.length;i++){
 $(f[i]).preventDoubleSubmission();
 }
});

小貼士

  • 提交按鈕需使用 type='submit' ,因為監聽的是表單的submit事件
  • 不建議多次監聽submit事件,會導致放重復提交失效
  • 在表單提交前通常會有些表單檢驗的操作,所以當校驗失敗的時候,可以通過 event.preventDefault() 阻止表單提交

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巩义市| 英山县| 西城区| 堆龙德庆县| 临安市| 德令哈市| 阳原县| 永善县| 宁海县| 宁德市| 甘肃省| 保靖县| 东方市| 肇庆市| 枣强县| 隆回县| 军事| 泰和县| 紫金县| 荆门市| 曲周县| 南开区| 北京市| 太谷县| 咸阳市| 江口县| 老河口市| 青州市| 抚宁县| 承德县| 海盐县| 共和县| 沙洋县| 奉贤区| 沁水县| 丰镇市| 梅州市| 车险| 合山市| 吉安市| 娱乐|