亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

前端防止用戶重復(fù)提交js實(shí)現(xiàn)代碼示例

 更新時(shí)間:2018年09月07日 14:10:49   作者:小黎也  
這篇文章主要給大家介紹了關(guān)于前端防止用戶重復(fù)提交js實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起看看吧

背景

前端在向后端進(jìn)行數(shù)據(jù)提交的時(shí)候,通常會(huì)需要在第一次提交返回前,阻止用戶在快速點(diǎn)擊發(fā)送二次請求,即防止重復(fù)提交,最簡單的方法是使用標(biāo)志參數(shù)或者 class 元素控制,但缺點(diǎn)是,每個(gè)控制重復(fù)提交的地方都需要加上這個(gè)邏輯,重復(fù)性太強(qiáng),且控制邏輯不統(tǒng)一。

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

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

下面這篇文章將給大家詳細(xì)介紹關(guān)于這兩種方法實(shí)現(xiàn)的方法示例,下面話不多說了,來隨著小編一起看看詳細(xì)的介紹吧

異步防重復(fù)提交的方案如下

通過 jQuery 提供的 ajaxPrefilter 方法,將在請求提交之前進(jìn)行過濾,僅保留第一次請求,后續(xù)的請求 abort 阻止掉,具體實(shí)現(xiàn)代碼如下

/**
 * _pendingRequests = {
 * 'http:xxx.xxxx.do':['domain=P2P','xxxx=aaa'],
 * 'http:xxx.yyyy.do':['domain=P3P','xxxx=bbb']
 * }
 * 該對象的 key 是請求的 url ,value 是由請求參數(shù)轉(zhuǎn)化成的字符串?dāng)?shù)組
 */
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) {
 //當(dāng)url相同時(shí),以此比較保存的參數(shù)對象,若參數(shù)對象相同,則返回false,若第一個(gè)就相同,則跳出循環(huán)
 // 反之說明當(dāng)前參數(shù)對象列表中沒有與將要提交的參數(shù)相同,則可看為不同的請求,返回true,允許發(fā)起請求
 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;
 };

 //若請求隊(duì)列中不存在或者同一個(gè)請求不同參數(shù),且不為html后綴,則加入隊(duì)列中
 if (( !_pendingRequests[p_item.key] || compareData(_pendingRequests[p_item.key],dataArray) ) && p_item.key.indexOf('.html') === -1) {
 //給 index 賦值是因?yàn)檎埱笫钱惒椒祷氐模琲ndex用于標(biāo)記第一個(gè)請求
 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(); // 放棄后觸發(fā)的重復(fù)提交,僅保留第一次提交
 //pendingRequests[key].abort(); // 放棄先觸發(fā)的提交
 }
 var complete = options.complete;
 //請求完成
 options.complete = function(jqXHR, textStatus) {
 // 通過 key 和 index 獲取成功返回的請求,將其值為 null ,下一次該請求便是在請求隊(duì)列中便是新的一個(gè)請求
 _pendingRequests[p_item.key][p_item.index] = null;
 if ($.isFunction(complete)) {
 complete.apply(this, arguments);
 }
 };
});

jquery.ajaxprefilter官方文檔

表單提交防重復(fù)提交的方案如下

表單的處理就稍微要麻煩點(diǎn),但大致思路和異步的相同,等待第一次請求返回的同時(shí),阻止后續(xù)觸發(fā)的請求發(fā)送
首先基于jquery擴(kuò)展了一個(gè)自定義的方法,如下

$.fn.preventDoubleSubmission = function() {
 $(this).on('submit', function(e) {
 var $form = $(this);
 // $form.data('submitted') 通過該變量判斷請求的狀態(tài)
 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;
};

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

為了方便對全站的表單提交統(tǒng)一處理,可對需要放重復(fù)提交的表單添加一個(gè)class preventDouble,在頁面渲染后,統(tǒng)一加上事件監(jiān)聽

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

小貼士

  • 提交按鈕需使用 type='submit' ,因?yàn)楸O(jiān)聽的是表單的submit事件
  • 不建議多次監(jiān)聽submit事件,會(huì)導(dǎo)致放重復(fù)提交失效
  • 在表單提交前通常會(huì)有些表單檢驗(yàn)的操作,所以當(dāng)校驗(yàn)失敗的時(shí)候,可以通過 event.preventDefault() 阻止表單提交

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • js setTimeout實(shí)現(xiàn)延遲關(guān)閉彈出層

    js setTimeout實(shí)現(xiàn)延遲關(guān)閉彈出層

    有時(shí)候我們希望彈出層能夠?qū)崿F(xiàn)延遲關(guān)閉,并且鼠標(biāo)在彈出層區(qū)域移動(dòng)的時(shí)候能夠保持顯現(xiàn),下面是具體的實(shí)現(xiàn)代碼。
    2010-04-04
  • js實(shí)現(xiàn)簡單選項(xiàng)卡制作

    js實(shí)現(xiàn)簡單選項(xiàng)卡制作

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)簡單選項(xiàng)卡制作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • 基于openlayers4實(shí)現(xiàn)點(diǎn)的擴(kuò)散效果

    基于openlayers4實(shí)現(xiàn)點(diǎn)的擴(kuò)散效果

    這篇文章主要為大家詳細(xì)介紹了基于openlayers4實(shí)現(xiàn)點(diǎn)的擴(kuò)散效果 ,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 詳解JavaScript邏輯And運(yùn)算符

    詳解JavaScript邏輯And運(yùn)算符

    這篇文章主要介紹了JavaScript邏輯And運(yùn)算符,在JavaScript中,邏輯 AND 運(yùn)算符用雙和號(&&)表示
    2015-12-12
  • js提交form表單,并傳遞參數(shù)的實(shí)現(xiàn)方法

    js提交form表單,并傳遞參數(shù)的實(shí)現(xiàn)方法

    下面小編就為大家?guī)硪黄猨s提交form表單,并傳遞參數(shù)的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-05-05
  • js 為label標(biāo)簽和div標(biāo)簽賦值的方法

    js 為label標(biāo)簽和div標(biāo)簽賦值的方法

    這篇文章介紹了js 為label標(biāo)簽和div標(biāo)簽賦值的方法,有需要的朋友可以參考一下
    2013-08-08
  • js Array.slice的8種不同用法示例

    js Array.slice的8種不同用法示例

    這篇文章主要給大家介紹了關(guān)于js Array.slice的8種不同用法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用js 具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 詳解bootstrap導(dǎo)航欄.nav與.navbar區(qū)別

    詳解bootstrap導(dǎo)航欄.nav與.navbar區(qū)別

    本篇文章主要介紹了詳解bootstrap導(dǎo)航欄.nav與.navbar區(qū)別,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • flash調(diào)用js中的方法,讓js傳遞變量給flash的辦法及思路

    flash調(diào)用js中的方法,讓js傳遞變量給flash的辦法及思路

    前幾天發(fā)表了 將FlashVars寫在JS函數(shù)中,實(shí)現(xiàn)與后臺(tái)的實(shí)時(shí)變量更新,但是僅支持 IE,隨后與 Luckyer 進(jìn)行了交流,發(fā)現(xiàn)用 SetVariable 可以很方便的實(shí)現(xiàn)多瀏覽器兼容。舉例如下。
    2013-08-08
  • 記錄微信小程序 height: calc(xx - xx);無效問題

    記錄微信小程序 height: calc(xx - xx);無效問題

    這篇文章主要介紹了微信小程序 - height: calc(xx - xx);無效 問題,文中給大家擴(kuò)展介紹下jquery點(diǎn)擊添加樣式,再次點(diǎn)擊移除樣式的實(shí)例代碼,需要的朋友可以參考下
    2019-12-12

最新評論