我們在前端總會遇到重複點擊的問題,由於網路的原因,用戶無法及時得到回饋,就很可能會選擇再點擊一次,所以這個時候就會向後端發送兩次重複的請求,這樣就很可能會導致嚴重的問題,尤其是在發post的時候,就可能會增加兩個重複的資料。本文主要為大家介紹了CSS利用pointer-events防止重複點擊的相關資料,文中透過範例程式碼介紹的非常詳細,對大家的學習或理解具有一定的參考學習價值,希望能幫助大家。
之前我通常遇到這種情況都會在js 的請求前做一個canRequest 變量,由於請求是異步的,所以在請求開始後我就會將該變量設置為false, 當請求結束後,無論成功或失敗都要將該變數設為true, 簡單程式碼如下:
var canRequest = true function postData () { if (!canRequest) return fetch(url) .then(res => { canRequest = true }) .catch(e => { canRequest = true }) canRequest = false }
這樣做並沒有什麼毛病,不過考慮到一般點擊後還需要將按鈕置灰,所以我找到了個從css 層面就阻止重複點擊的方式。
下面是個取得簡訊驗證碼的範例:
<p id="count">获取验证码</p>
body { display: flex; height: 100vh; } #count { margin: auto; padding: 10px; width: 100px; border: 1px solid; text-align: center; cursor: pointer; border-radius: 4px; } .disable { pointer-events: none; color: #666; }
const count = document.getElementById('count') const tip = count.textContent count.onclick = e => { console.log(111) count.classList.add('disable') count.textContent = 10 var id = setInterval(() => { count.textContent-- if (count.textContent <= 0) { count.classList.remove('disable') count.textContent = tip clearInterval(id) } }, 1000) }
相關推薦:
以上是利用pointer-events防止重複點擊的方法實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!