JS實現(xiàn)用戶注冊時獲取短信驗證碼和倒計時功能
在用戶注冊時,通常需要短信驗證碼,而且為了交互效果,也需要增加倒計時。
效果如下:
<div class="user-form"> <form action="{{ path('zm_member_register') }}" method="post"> <div class="form-list"> <label class="register-label">手機號碼</label> <input class="regphone input-register" type="text" name="phone" placeholder="請輸入手機號碼" /> </div> <div class="form-list"> <label class="register-label">驗證碼</label> <input class="input-short" type="text" name="sms_salt" placeholder="請輸短信驗證碼" /> <input class="input-code" id="btn" type="button" value="發(fā)送驗證碼" /> </div> <input style="margin-top: 60px;" type="submit" class="registerSubmit form-sumbit" value="提交" /> </form> </div>
這里的驗證碼是通過向后臺這個url({{ path(‘zm_member_get_salt') }}))里面,傳手機號碼和類型(type=1為注冊)這兩個值,后臺接收值成功則返回成功狀態(tài)值。
基于這里,實現(xiàn)驗證碼倒計時,即可以在判斷成功后。調(diào)用封裝了的倒計時函數(shù) time(),注意驗證碼應使用type為button的input,此時可以方便地更改其value值,來展示倒計時的時間。
<script type="text/javascript"> //倒計時60秒 var wait=60; function time(o) { if (wait == 0) { o.removeAttribute("disabled"); o.value="獲取動態(tài)碼"; wait = 60; } else { o.setAttribute("disabled", true); o.value="重新發(fā)送(" + wait + ")"; wait--; setTimeout(function() { time(o) }, 1000) } } $('.input-code').click(function() { var phone = $('.regphone').val(); $.ajax({ type: 'post', url: "{{ path('zm_member_get_salt') }}", data: { phone: phone, type: 1 }, dataType: 'json', success: function (result) { if (result.flag == 1) { // alert('成功'); time(btn); } else { alert(result.content); } } }); }); </script>
以上所述是小編給大家介紹的JS實現(xiàn)用戶注冊時獲取短信驗證碼和倒計時功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持
相關(guān)文章
點擊按鈕自動加關(guān)注的代碼(sina微博/QQ空間/人人網(wǎng)/騰訊微博)
本篇文章主要介紹了點擊按鈕自動加關(guān)注代碼(sina微博/QQ空間/人人網(wǎng)/騰訊微博) 需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01javascript內(nèi)置對象Math案例總結(jié)分析
今天總結(jié)一下javascript 內(nèi)置對象Math中的函數(shù)用法,順帶寫一下常見的案例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-03-03JavaScript錯誤處理之分析 Uncaught(in promise) error的
在開發(fā)過程中,JavaScript的錯誤處理是一個老生常談的話題,當應用程序發(fā)生未捕獲的異常時,Uncaught(in promise) error是其中最常見的錯誤類型,這篇文章將從多個方面詳細闡述這種錯誤類型的原因與解決方案,感興趣的朋友一起看看吧2023-12-12用JavaScript事件串連執(zhí)行多個處理過程的方法
用JavaScript事件串連執(zhí)行多個處理過程的方法...2007-03-03Bootstrap的aria-label和aria-labelledby屬性實例詳解
這篇文章主要介紹了Bootstrap的aria-label和aria-labelledby屬性實例詳解,需要的朋友可以參考下2018-11-11