Vue寫一個簡單的倒計時按鈕功能
在項目開發(fā)里,我們經(jīng)常會遇到發(fā)送驗證碼、點(diǎn)擊了之后有60秒倒計時的按鈕,很常見卻也很簡單,但是在寫這個按鈕的時候有個別地方還要注意下,今天寫出來,如有問題歡迎指正!
完成的效果如下:
為了更快顯示出效果,我把時間設(shè)成了5秒。按鈕在點(diǎn)擊之后會出現(xiàn)倒計時,同時按鈕變?yōu)椴豢牲c(diǎn)擊狀態(tài),樣式也發(fā)生變化,鼠標(biāo)懸浮上的樣子也會發(fā)生變化。
接下來我們用代碼來實(shí)現(xiàn):
<button class="button" @click="countDown"> {{content}} </button> ... data () { return { content: '發(fā)送驗證碼', // 按鈕里顯示的內(nèi)容 totalTime: 60 //記錄具體倒計時時間 } }, methods: { countDown() { let clock = window.setInterval(() => { this.total-- this.content = this.total + 's后重新發(fā)送' },1000) } }
在data里加了兩條數(shù)據(jù),一條用來記錄時間,一條用來盛放倒計時按鈕的具體內(nèi)容。在countDown函數(shù)里我們用了setInterval定時器,每隔一秒totalTime減1,同時更改按鈕里顯示的內(nèi)容。 在window.setInterval里用了箭頭函數(shù),因為它會自動綁定外面的this,所以就不用先存下this了。
效果如下圖:
但是這個按鈕還有一些問題:
點(diǎn)擊了按鈕之后過了1秒就直接從59秒開始倒計時了,中間的60不見了
倒計時的時候還可以點(diǎn)擊
還沒有清除倒計時
接下來需要繼續(xù)完善countDown函數(shù)來解決這些問題。
countDown () { this.content = this.totalTime + 's后重新發(fā)送' //這里解決60秒不見了的問題 let clock = window.setInterval(() => { this.totalTime-- this.content = this.totalTime + 's后重新發(fā)送' if (this.totalTime < 0) { //當(dāng)?shù)褂嫊r小于0時清除定時器 window.clearInterval(clock) this.content = '重新發(fā)送驗證碼' this.totalTime = 60 } },1000) },
上面的代碼解決了60不見的問題,同時當(dāng)totalTime小于0時清除同時器、重新設(shè)置按鈕里的content、將totalTime重置為60以便下次使用。
倒計10秒的效果:
發(fā)現(xiàn)bug,多次點(diǎn)擊之后,倒講時速度變快,這是因為每次點(diǎn)擊都會啟動一個setInterval,這些setInterval都會減少totalTime。解決的方法也很簡單:簡單節(jié)流一下就好了,就是第一次點(diǎn)擊按鈕之后讓countDonw這個函數(shù)的代碼不可執(zhí)行,等到倒計時結(jié)束之后才可以再次執(zhí)行。
data () { return { content: '發(fā)送驗證碼', totalTime: 10, canClick: true //添加canClick } } ... countDown () { if (!this.canClick) return //改動的是這兩行代碼 this.canClick = false this.content = this.totalTime + 's后重新發(fā)送' let clock = window.setInterval(() => { this.totalTime-- this.content = this.totalTime + 's后重新發(fā)送' if (this.totalTime < 0) { window.clearInterval(clock) this.content = '重新發(fā)送驗證碼' this.totalTime = 10 this.canClick = true //這里重新開啟 } },1000) }
在data里添加canClick,默認(rèn)是true,如果canClick為true,countDown里的代碼可以執(zhí)行,如果是false就不行。每執(zhí)行一次就將canClick設(shè)為false,而只在倒計時結(jié)束的時候再改為true。這樣剛才的問題就沒有了。
到這里其實(shí)就差不多了,不過還可以調(diào)整下樣式:
<button class="button" :class="{disabled: !this.canClick}" @click="countDown"> ... .disabled{ background-color: #ddd; border-color: #ddd; color:#57a3f3; cursor: not-allowed; // 鼠標(biāo)變化 }
效果:
這個倒計時按鈕十分簡單,但是我第一次寫的時候還是寫的很亂,而且那個時候還不知道函數(shù)節(jié)流的概念。
總結(jié)
以上所述是小編給大家介紹的Vue寫一個簡單的倒計時按鈕功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue源碼中要const _toStr = Object.prototype.toString的原因分析
這篇文章主要介紹了Vue源碼中要const _toStr = Object.prototype.toString的原因分析,在文中給大家提到了Object.prototype.toString方法的原理,需要的朋友可以參考下2018-12-12解決element-ui的el-select選擇器的@blur事件失效的坑
這篇文章主要介紹了解決element-ui的el-select選擇器的@blur事件失效的坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09Vue3+Vite+ElementPlus管理系統(tǒng)常見問題
本文記錄了使用Vue3+Vite+ElementPlus從0開始搭建一個前端工程會面臨的常見問題,沒有技術(shù)深度,但全都是解決實(shí)際問題的干貨,可以當(dāng)作是問題手冊以備后用,感興趣的朋友參考下2023-12-12使用Vue進(jìn)行數(shù)據(jù)可視化實(shí)踐分享
在當(dāng)今的數(shù)據(jù)驅(qū)動時代,數(shù)據(jù)可視化變得越來越重要,它能夠幫助我們更直觀地理解數(shù)據(jù),從而做出更好的決策,在這篇博客中,我們將探索如何使用 Vue 和一些常見的圖表庫(如 Chart.js)來制作漂亮的數(shù)據(jù)可視化效果,需要的朋友可以參考下2024-10-10vue使用關(guān)于speak-tss插件的詳細(xì)介紹及一些配置項
本文詳細(xì)介紹了speak-tss插件在Vue3中的使用方法和配置,首先需要下載依賴,然后引入插件,并進(jìn)行實(shí)例化和配置,配置項包括音量、語言、語音、語速、音調(diào)等,speak-tss支持多種語言和語音,適用于需要文本語音播報的場景2024-09-09Vue實(shí)現(xiàn)監(jiān)聽某個元素滾動,親測有效
這篇文章主要介紹了Vue實(shí)現(xiàn)監(jiān)聽某個元素滾動,親測有效!具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07