react實作手機驗證碼的方法:1、下載antd button和input元件;2、透過「 」取得客戶的手機號碼;3、透過「await this.props.sendCode({...})」實現取得驗證碼即可。
本教學操作環境:Windows10系統、react18.0.0版、Dell G3電腦。
react怎麼實作手機驗證碼?
React結合antd 實作手機或信箱取得驗證碼60秒倒數
我這邊是使用了antd button 和input 元件,若大家需要提前下載
import { Input, Button } from ‘antd’ <div> <p className={`littleTitle`}>手机号</p> <Input className={`apiMobileInput`} disabled value={this.props.phoneNumber} />//这个value是客户手机号,是我在客户信息里面获取到的 <p className={`littleTitle`}>获取验证码</p> <Input className={`apiInput`} addonAfter={ <button //判断如果点击了获取验证码,就让button按钮上显示 *秒后重发送 并且button设置为disabled disabled={this.props.liked ? false : true} onClick={() => this.getCode(theme)}//点击此按钮获取验证码 className={`verificationCode`}>{this.state.liked ? 获取验证码:(60)秒后重发} </button>} /> </div> //获取验证码 getCode = async theme => { //我这边是获取了客户信息,从中取到客户的手机号和邮箱,若客户绑定了手机号,就通过手机号验证,若没有绑定手机号,就通过邮箱验证码验证 const { data } = this.props.information.data //这个是获取当前语言 let lang = getLocalStorage('defaultLanguage') //得到语言Id let langId = lang === 'Chinese' ? 'zh' : lang === 'English' ? 'en' : lang === 'Japanese' ? 'ja' : '' //把手机号和语言id传入后台,获取验证码 const status = await this.props.sendCode({ mobileOrEmail: data.mobile ? data.mobile : data.email, langId: langId }) //调用下面查看验证码发送的状态方法 this.getSendCodeStatus(status,theme) } //倒计时 countDown() { const { count } = this.state if (count === 1) {//当为0的时候,liked设置为true,button按钮显示内容为 获取验证码 this.setState({ count: 60, liked: true, }) } else { this.setState({ count: count - 1, liked: false, }) setTimeout(() => this.countDown(), 1000)//每一秒调用一次 } } //发送验证码是否成功 getSendCodeStatus = async (status,theme) => { if (status.success === false) {//若发送失败,提示客户信息发送失败,不进行倒计时 sendCodeError(theme) } else { sendCodeSuccess(theme)//若发送成功,liked设为false,意味着发送验证码的按钮将被会禁用 this.setState({ authCode: '', email: '', liked: false, }) this.countDown()//调用倒计时 } }
想法:
客戶點擊取得驗證碼的時候,需要先有客戶的手機號,把手機號傳入後台,取得驗證碼,我這邊做的時候,是判斷了是否發送驗證碼成功,成功以後才執行60秒倒數計時,到倒數計時為0的時候,把liked設為true,button的內容恢復為獲取驗證碼
//效果圖
推薦學習:《react影片教學》
以上是react怎麼實作手機驗證碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!