欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript防止重復(fù)提交的三種解決方案

 更新時間:2025年07月24日 11:13:13   作者:~風(fēng)清揚(yáng)~  
防止JavaScript重復(fù)點(diǎn)擊和提交需結(jié)合前端禁用按鈕、節(jié)流和標(biāo)志位,這篇文章主要介紹了JavaScript防止重復(fù)提交的三種解決方案,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

防止 javascript 重復(fù)點(diǎn)擊和提交的關(guān)鍵方法有三種:1. 禁用按鈕法,點(diǎn)擊后立即禁用按鈕并更改文本提示,請求完成后恢復(fù);2. 節(jié)流函數(shù)(throttle),限制函數(shù)在設(shè)定時間間隔內(nèi)僅執(zhí)行一次,適用于非即時響應(yīng)場景;3. 使用標(biāo)志位,通過變量標(biāo)記操作狀態(tài)以阻止重復(fù)觸發(fā)。此外,前端可通過按鈕文本變化或加載動畫提升用戶提示體驗(yàn),而后端則可通過 token 機(jī)制、悲觀鎖/樂觀鎖及冪等性設(shè)計確保數(shù)據(jù)一致性與安全性。選擇方案應(yīng)根據(jù)具體場景決定,前端與后端結(jié)合使用可提供更全面的防護(hù)。

防止 JavaScript 重復(fù)點(diǎn)擊和提交,關(guān)鍵在于控制用戶行為,避免短時間內(nèi)多次觸發(fā)相同操作。這不僅僅是用戶體驗(yàn)的問題,更關(guān)系到數(shù)據(jù)一致性和服務(wù)器壓力。

解決方案

1.禁用按鈕法:

這是最直接也最常用的方法。點(diǎn)擊按鈕后,立即禁用它,防止用戶再次點(diǎn)擊。待請求完成后,再重新啟用按鈕。

const button = document.getElementById('myButton');

button.addEventListener('click', function() {
  button.disabled = true;
  button.textContent = '處理中...'; // 可選:更改按鈕文本提示用戶

  // 模擬一個異步請求
  setTimeout(() => {
    // 請求成功或失敗后的處理
    button.disabled = false;
    button.textContent = '提交'; // 恢復(fù)按鈕文本
  }, 2000);
});

這種方法的優(yōu)點(diǎn)是簡單易懂,缺點(diǎn)是用戶體驗(yàn)可能略差,因?yàn)榘粹o禁用期間無法進(jìn)行任何操作??梢越Y(jié)合按鈕文本的變化來改善用戶體驗(yàn)。

2.節(jié)流函數(shù)(Throttle):

使用節(jié)流函數(shù)可以限制函數(shù)在一定時間內(nèi)只能執(zhí)行一次。這適用于那些不需要立即響應(yīng)的場景,比如搜索框的輸入事件。 

function throttle(func, delay) {
  let timeoutId;
  let lastExecTime = 0;

  return function(...args) {
    const now = Date.now();
    const timeSinceLastExec = now - lastExecTime;

    if (!timeoutId) {
      if (timeSinceLastExec >= delay) {
        func.apply(this, args);
        lastExecTime = now;
      } else {
        timeoutId = setTimeout(() => {
          func.apply(this, args);
          lastExecTime = Date.now();
          timeoutId = null;
        }, delay - timeSinceLastExec);
      }
    }
  };
}

const myFunc = () => {
  console.log("函數(shù)執(zhí)行");
};

const throttledFunc = throttle(myFunc, 1000); // 1秒內(nèi)只允許執(zhí)行一次

// 多次調(diào)用 throttledFunc,但實(shí)際上只有在間隔超過 1 秒時才會執(zhí)行
throttledFunc();
throttledFunc();
setTimeout(throttledFunc, 500);
setTimeout(throttledFunc, 1200);

節(jié)流函數(shù)的核心在于時間控制,確保函數(shù)在規(guī)定的時間間隔內(nèi)只執(zhí)行一次。

3.使用標(biāo)志位:

定義一個變量來標(biāo)記是否正在進(jìn)行操作。如果正在進(jìn)行操作,則忽略后續(xù)的點(diǎn)擊事件

let isSubmitting = false;

const form = document.getElementById('myForm');

form.addEventListener('submit', function(event) {
  event.preventDefault(); // 阻止默認(rèn)的表單提交

  if (isSubmitting) {
    console.log('正在提交,請稍候...');
    return;
  }

  isSubmitting = true;
  console.log('開始提交...');

  // 模擬一個異步提交
  setTimeout(() => {
    console.log('提交完成!');
    isSubmitting = false;
  }, 3000);
});

這種方法簡單直接,但需要注意在異步操作完成后,一定要將標(biāo)志位重置,否則后續(xù)操作將無法進(jìn)行。

如何選擇最合適的防止重復(fù)提交方案?

這取決于你的具體應(yīng)用場景。如果只需要簡單地防止按鈕被連續(xù)點(diǎn)擊,禁用按鈕法是最簡單的選擇。如果需要限制函數(shù)在一定時間內(nèi)只能執(zhí)行一次,節(jié)流函數(shù)更合適。如果需要更精細(xì)的控制,比如在表單提交過程中防止重復(fù)提交,使用標(biāo)志位可能更靈活。

禁用按鈕后,如何優(yōu)雅地提示用戶正在處理中?

僅僅禁用按鈕可能讓用戶感到困惑,不知道發(fā)生了什么。更好的做法是結(jié)合按鈕文本的變化,例如將按鈕文本改為“處理中...”或顯示一個加載動畫。此外,還可以使用模態(tài)框或消息提示來告知用戶當(dāng)前的狀態(tài)。

const button = document.getElementById('myButton');
const originalText = button.textContent;

button.addEventListener('click', function() {
  button.disabled = true;
  button.textContent = '處理中...'; // 更改按鈕文本
  button.classList.add('loading'); // 添加一個 loading class,用于顯示加載動畫

  // 模擬一個異步請求
  setTimeout(() => {
    // 請求成功或失敗后的處理
    button.disabled = false;
    button.textContent = originalText; // 恢復(fù)按鈕文本
    button.classList.remove('loading'); // 移除 loading class
  }, 2000);
});

 在 CSS 中定義 .loading 類,例如:

.loading {
  position: relative;
  padding-right: 25px; /* 為加載動畫預(yù)留空間 */
}

.loading::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 5px;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  border: 2px solid #ccc;
  border-top-color: #333;
  animation: spin 1s linear infinite;
  transform: translateY(-50%);
}

@keyframes spin {
  to {
    transform: translateY(-50%) rotate(360deg);
  }
}

除了前端,后端如何防止重復(fù)提交?

前端的防止重復(fù)提交只能解決一部分問題,更可靠的方案是在后端進(jìn)行驗(yàn)證。常見的后端防止重復(fù)提交的方法包括:

  • Token 機(jī)制: 在前端頁面生成一個唯一的 Token,每次提交請求時都帶上這個 Token。后端驗(yàn)證 Token 的有效性,如果 Token 已經(jīng)被使用過,則拒絕本次請求。
  • 悲觀鎖/樂觀鎖: 在數(shù)據(jù)庫層面使用鎖機(jī)制,確保同一時間只有一個請求可以修改數(shù)據(jù)。
  • 冪等性設(shè)計: 將接口設(shè)計成冪等的,即使多次調(diào)用,結(jié)果也應(yīng)該是一致的。例如,可以使用唯一 ID 來標(biāo)識請求,后端根據(jù) ID 來判斷是否已經(jīng)處理過該請求。

后端防止重復(fù)提交是更可靠的方案,可以有效地防止惡意攻擊和網(wǎng)絡(luò)延遲等問題導(dǎo)致的重復(fù)提交。

總結(jié)

到此這篇關(guān)于JavaScript防止重復(fù)提交的三種解決方案的文章就介紹到這了,更多相關(guān)js防止重復(fù)提交內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 對JavaScript的eval()中使用函數(shù)的進(jìn)一步討論

    對JavaScript的eval()中使用函數(shù)的進(jìn)一步討論

    《JavaScript語言精髓與編程實(shí)踐》的讀者I22141提出了一問題:為什么下面這段代碼在JScript 和SpiderMonkey中表現(xiàn)不一樣:
    2008-07-07
  • JavaScript 中的 Map使用指南

    JavaScript 中的 Map使用指南

    本文詳細(xì)介紹了JavaScript中的Map數(shù)據(jù)結(jié)構(gòu),包括它的創(chuàng)建、常用方法、迭代方式以及與對象的區(qū)別,文章簡要介紹了WeakMap的概念和使用場景,感興趣的朋友一起看看吧
    2025-02-02
  • 使用JavaScript和CSS實(shí)現(xiàn)簡單的字符計數(shù)器

    使用JavaScript和CSS實(shí)現(xiàn)簡單的字符計數(shù)器

    在本文中,你將學(xué)習(xí)如何使用?JavaScript?創(chuàng)建字符計數(shù)器。計數(shù)的數(shù)字可以在小顯示屏中看到。文中示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-08-08
  • 第五篇Bootstrap 排版

    第五篇Bootstrap 排版

    使用bootstrap的排版特性可以創(chuàng)建標(biāo)題,段落,列表及其它內(nèi)聯(lián)元素。本文重點(diǎn)給大家介紹Bootstrap 排版 知識,非常不錯,具有參考借鑒價值,感興趣的朋友一起學(xué)習(xí)吧
    2016-06-06
  • layui時間控件選擇時間范圍的實(shí)現(xiàn)方法

    layui時間控件選擇時間范圍的實(shí)現(xiàn)方法

    今天小編就為大家分享一篇layui時間控件選擇時間范圍的實(shí)現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • js校驗(yàn)開始時間和結(jié)束時間

    js校驗(yàn)開始時間和結(jié)束時間

    這篇文章主要為大家詳細(xì)介紹了js校驗(yàn)開始結(jié)束時間,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • JavaScript中條件語句的優(yōu)化技巧總結(jié)

    JavaScript中條件語句的優(yōu)化技巧總結(jié)

    這篇文章主要給大家介紹了關(guān)于JavaScript中條件語句的優(yōu)化技巧,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • js 無提示關(guān)閉瀏覽器頁面的代碼

    js 無提示關(guān)閉瀏覽器頁面的代碼

    js 無提示關(guān)閉瀏覽器頁面的代碼與函數(shù)需要的朋友可以參考下。
    2010-03-03
  • 一篇文中告訴你JS中的"值傳遞"和"引用傳遞"

    一篇文中告訴你JS中的"值傳遞"和"引用傳遞"

    在JavaScript中,可以通過值和引用傳遞,兩者之間的主要區(qū)別是,按值傳遞發(fā)生在賦值基本類型的時候,而賦值對象時按引用傳遞,下面這篇文章主要給大家介紹了關(guān)于JS中"值傳遞"和"引用傳遞"的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • 微信小程序textarea層級過高(蓋住其他元素)問題的解決辦法

    微信小程序textarea層級過高(蓋住其他元素)問題的解決辦法

    這篇文章主要給大家介紹了關(guān)于微信小程序textarea層級過高(蓋住其他元素)問題的解決辦法,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03

最新評論