真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ReactNative短信驗證碼倒計時控件的實現(xiàn)代碼

由于最近剛開始認真的搞RN,可能有一些封裝的不是最佳實踐,還是希望大家多提意見,和大家一起進步吧。本文介紹了ReactNative短信驗證碼倒計時控件,分享給大家

創(chuàng)新互聯(lián)服務項目包括興城網(wǎng)站建設、興城網(wǎng)站制作、興城網(wǎng)頁制作以及興城網(wǎng)絡營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯(lián)網(wǎng)行業(yè)的解決方案,興城網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務的客戶以成都為中心已經(jīng)輻射到興城省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!

功能

根據(jù)項目的需要,需要寫一個自定義的控件,實現(xiàn)如下功能:

  1. 默認文字為點擊獲取驗證碼
  2. 點擊后出現(xiàn)60秒的倒計時
  3. 顏色,字號可調
  4. 倒計時過程中,再次點擊需要忽略掉
  5. 倒計時完成后文本恢復成點擊獲取驗證碼
  6. 再幾次點擊同之前

其實說了這么多,就是個最普通的驗證碼的功能。。。

效果

效果圖如下:(錄的圖片比較一般,對付著看吧)

ReactNative短信驗證碼倒計時控件的實現(xiàn)代碼

實現(xiàn)原理

自己封裝了個控件,它內部含有一個Text控件,然后我們又寫了一個timer,然后負責倒計時,然后每次都需要判斷一下是否繼續(xù),然后加了一個flag字段,判斷是否接受下次點擊事件,當?shù)褂嫊r結束之后還需要將初始狀態(tài)重置回去即可。

代碼

控件代碼

import React, {Component } from 'react';
import {
  StyleSheet,
  Text,
  View,
  Image,
  TextInput,
  TouchableHighlight,
  StatusBar,
  Alert,
  AppRegistry
} from 'react-native';
import LinkRow from '../components/LinkRow';
import cStyles from '../styles/CommonStyle';

import axios from 'axios';

class MyCountTime extends Component {
  constructor(props) {
    super(props);
    let timeLeft = this.props.timeLeft > 0 ? this.props.timeLeft : 5;
    let width = this.props.width || 100;
    let height = this.props.height || 50;
    let color = this.props.color || '#42A5F5';
    let fontSize = this.props.fontSize || 30;
    let fontWeight = this.props.fontWeight || '600';
    let borderColor = this.props.borderColor || '#42A5F5';
    let borderWidth = this.props.borderWidth || 1;
    let borderRadius = this.props.borderRadius || 4;
    let backgroundColor = this.props.backgroundColor || '#42A5F5';
    let begin = 0;
    let press = this.props.press;

    this.afterEnd = this.props.afterEnd || this._afterEnd;
    this.style = this.props.style;

    this.state = {
      timeLeft: timeLeft,
      begin: begin
    };
    this.countTextStyle = {
      textAlign: 'center',
      color: '#42A5F5',
      fontSize: fontSize,
      fontWeight: fontWeight

    };
    this.countViewStyle = {
      backgroundColor: backgroundColor,
      alignItems: 'center',
      borderColor: borderColor,
      borderWidth: borderWidth,
      borderRadius: borderRadius,
      width: width,
      height: height
    }
  }

  countdownfn(timeLeft, callback, begin) {
    if (timeLeft > 0) {
      this.state.begin = 1;
      console.log("===lin===>");

      let that = this;
      let interval = setInterval(function () {
        if (that.state.timeLeft < 1) {
          clearInterval(interval);
          callback(that)
        } else {
          let totalTime = that.state.timeLeft;
          that.setState({
            timeLeft: totalTime - 1
          })
        }
      }, 1000)
    }
  }

  _beginCountDown() {
    if (this.state.begin === 1){
      return;
    }
    let time = this.state.timeLeft;
    console.log("===lin===> time " + time);
    let afterEnd = this.afterEnd;
    let begin = this.state.begin;
    console.log("===lin===> start " + begin);
    this.countdownfn(time, afterEnd, begin)
  }

  _afterEnd(that) {
    console.log('------------time over');
    that.setState({
      begin : 0,
      timeLeft : 5,
    })
  }

  componentDidMount() {

  }

  render() {
    return (
      
         { this.state.begin === 0 ? '點擊獲取驗證碼' : this.state.timeLeft} 

      
    )
  }
}

應用代碼




當然這只是,最簡單的應用的代碼,我們還提供了很多的自定義的屬性,大家可以根據(jù)自己項目的需要,去調節(jié)這些參數(shù)。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


新聞名稱:ReactNative短信驗證碼倒計時控件的實現(xiàn)代碼
網(wǎng)頁網(wǎng)址:http://weahome.cn/article/jddcdh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部