vue實現(xiàn)驗證碼按鈕倒計時功能
本人最近開始嘗試學(xué)習(xí)vue.js。想使用vue寫一個小例子,就選擇做驗證碼按鈕倒計時功能。
上網(wǎng)上搜了一下,也把他們的代碼試了一下,自己出了很多問題。所以,需要寫一篇基礎(chǔ)入門的文章,避免后面人采坑。
這是按照網(wǎng)上寫的HTML頁面
<div class="register-pannel" id ="register-pannel"> <div class="register-l" align="center"> <div class="input-group" style="width: 300px;"> <input type="text" class="form-control" placeholder="郵箱/手機號/用戶名" style="height: 40px;" /> <span class="glyphicon glyphicon-user form-control-feedback" aria-hidden="true" /> </div> <br /> <div class="input-group" style="width: 300px;"> <input type="text" class="form-control" placeholder="密碼" style="height: 40px;" /> <span class="glyphicon glyphicon-lock form-control-feedback" /> </div> <br /> <div class="input-group" style="width: 300px;"> <input type="text" class="form-control" placeholder="手機號" style="height: 40px;" /> <span class="glyphicon glyphicon-phone form-control-feedback" /> </div> <br /> <div class="input-group" style="width: 300px;"> <span class="register-msg-btn" v-show="show" v-on:click="getCode">發(fā)送驗證碼</span> <span class="register-msg-btn" v-show="!show">{{count}} s</span> <input type="text" class="form-control" placeholder="驗證碼" style="float: right; height: 40px; width: 150px;" /> <span class="glyphicon glyphicon-font form-control-feedback" /> </div> <br /> <span class="btn-register">注冊</span> </div>
js寫成
<script> <span style="white-space: pre;"> </span>data(){ <span style="white-space: pre;"> </span>return { <span style="white-space: pre;"> </span>show: true, <span style="white-space: pre;"> </span>count: '', <span style="white-space: pre;"> </span>timer: null, <span style="white-space: pre;"> </span>} <span style="white-space: pre;"> </span>}, <span style="white-space: pre;"> </span>methods:{ <span style="white-space: pre;"> </span>getCode(){ <span style="white-space: pre;"> </span>const TIME_COUNT = 60; <span style="white-space: pre;"> </span>if (!this.timer) { <span style="white-space: pre;"> </span>this.count = TIME_COUNT; <span style="white-space: pre;"> </span>this.show = false; <span style="white-space: pre;"> </span>this.timer = setInterval(() => { <span style="white-space: pre;"> </span>if (this.count > 0 && this.count <= TIME_COUNT) { <span style="white-space: pre;"> </span>this.count--; <span style="white-space: pre;"> </span>} else { <span style="white-space: pre;"> </span>this.show = true; <span style="white-space: pre;"> </span>clearInterval(this.timer); <span style="white-space: pre;"> </span>this.timer = null; <span style="white-space: pre;"> </span>} <span style="white-space: pre;"> </span>}, 1000) <span style="white-space: pre;"> </span>} <span style="white-space: pre;"> </span>} <span style="white-space: pre;"> </span>} </script>
發(fā)現(xiàn)瀏覽器一直報錯Uncaught SyntaxError: Unexpected token {
所以按照官方文檔的格式,把js的結(jié)構(gòu)改成
<script> new Vue({ el:'.register-pannel', data:{ show:true, timer:null, count:'' }, methods:{ getCode(){ this.show = false; const TIME_COUNT = 60; if (!this.timer) { this.count = TIME_COUNT; this.show = false; this.timer = setInterval(() => { if (this.count > 0 && this.count <= TIME_COUNT) { this.count--; } else { this.show = true; clearInterval(this.timer); this.timer = null; } }, 1000) } } } }); </script>
于是格式是沒有問題了,但是樣式并沒有生效。變成了另一個樣子。
上網(wǎng)上搜了很多。
有說是js引用順序的問題。
有說是將js寫進window.onload
的。試了一下,發(fā)現(xiàn)都不對。
后來,在官方文檔中發(fā)現(xiàn)了el屬性:為實例提供掛載元素。值可以是 CSS 選擇符,或?qū)嶋H HTML 元素,或返回 HTML 元素的函數(shù)。
所以改成
<script> new Vue({ el:'.register-pannel', //注冊div的class data:{ show:true, timer:null, count:'' }, methods:{ getCode(){ this.show = false; const TIME_COUNT = 60; if (!this.timer) { this.count = TIME_COUNT; this.show = false; this.timer = setInterval(() => { if (this.count > 0 && this.count <= TIME_COUNT) { this.count--; } else { this.show = true; clearInterval(this.timer); this.timer = null; } }, 1000) } } } }); </script>
效果就出來了。
總結(jié)
以上所述是小編給大家介紹vue實現(xiàn)驗證碼按鈕倒計時功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue?基于?vuedraggable?實現(xiàn)選中、拖拽、排序效果
這篇文章主要介紹了Vue?基于?vuedraggable?實現(xiàn)選中、拖拽、排序效果,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05輕量級富文本編輯器wangEditor結(jié)合vue使用方法示例
在我們項目中,有些時候需要使用富文本編輯器。本文將以百度開發(fā)的Ueditor結(jié)合Vue.js介紹一下。非常具有實用價值,需要的朋友可以參考下2018-10-10Vue表格首列相同數(shù)據(jù)合并實現(xiàn)方法
這篇文章主要介紹了Vue實現(xiàn)表格首列相同數(shù)據(jù)合并的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04解決在vue項目中,發(fā)版之后,背景圖片報錯,路徑不對的問題
下面小編就為大家分享一篇解決在vue項目中,發(fā)版之后,背景圖片報錯,路徑不對的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03Vue?設(shè)置圖片不轉(zhuǎn)為base64的方式
這篇文章主要介紹了Vue實現(xiàn)設(shè)置圖片不轉(zhuǎn)為base64的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02