首頁 > web前端 > css教學 > 利用pointer-events防止重複點擊的方法實例

利用pointer-events防止重複點擊的方法實例

小云云
發布: 2017-12-19 09:57:30
原創
1771 人瀏覽過

我們在前端總會遇到重複點擊的問題,由於網路的原因,用戶無法及時得到回饋,就很可能會選擇再點擊一次,所以這個時候就會向後端發送兩次重複的請求,這樣就很可能會導致嚴重的問題,尤其是在發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)
}
登入後複製

相關推薦:

a:active加動畫點擊無效的解決方案

#css3點選顯示漣漪特效

JS點選連結切換顯示隱藏內容的實作方法

以上是利用pointer-events防止重複點擊的方法實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板