react-native計(jì)時(shí)器-倒計(jì)時(shí)

語錄:作為一個(gè)真正的程序員董朝,首先應(yīng)該尊重編程灰瞻,熱愛你所寫下的程序腥例,他是你的伙伴,而不是工具

目標(biāo):開發(fā)一款倒計(jì)時(shí)的插件酝润。用于短信驗(yàn)證碼倒計(jì)時(shí)燎竖,用于商城秒殺倒計(jì)時(shí)等等。

最終結(jié)果展示

版本:

"dependencies": {
    "react": "16.0.0-alpha.12",
    "react-native": "0.47.1"
},
//代碼直接拷貝可用要销。

思路:

分三個(gè)步驟:
1.計(jì)時(shí)開始构回,處理秒:
如果秒為0,則請(qǐng)求分鐘函數(shù)蕉陋。如果分鐘返回的是0捐凭,則終止計(jì)時(shí)。
2.分鐘處理:
如果分鐘為0凳鬓,則從小時(shí)哪里請(qǐng)求茁肠,如果請(qǐng)求到0,說明時(shí)間計(jì)時(shí)結(jié)束缩举,返回0垦梆;
如果分鐘為0匹颤,從小時(shí)哪里請(qǐng)求到1,說明請(qǐng)求成功托猩,將分鐘設(shè)置為59印蓖,返回1;
如果分鐘不為0京腥,則分鐘自身-1赦肃。
3.小時(shí)處理:
如果小時(shí)不為0,則自身-1公浪,返回1他宛;
如果小時(shí)為0,直接返回0欠气。

代碼實(shí)現(xiàn):

/**
 * 開發(fā)者:杜二紅<1186969412@qq.com>
 * http://www.uminicmf.com
 * QQ:1186969412 微信:uminicmf
 */
import React, { Component } from 'react';
import {
    AppRegistry,
    StyleSheet,
    View,
    Text,
    Button
} from 'react-native';
export default class Login extends Component {
  constructor(props){
    super(props);
    this.state={
      hour:'1',
      minutes:'0',
      seconds:'2',
    }
    // countTime();
  }
  render() {
    return (
      <View  style={{flex:1,justifyContent:'center',alignItems:'center'}}>
        <Text style={{fontSize:22}}>{this.state.hour}:{this.state.minutes}:{this.state.seconds}</Text>
        <Button
          onPress={this.countTime.bind(this)}
          title="開始計(jì)時(shí)"
          color="#841584"
          accessibilityLabel="開始計(jì)時(shí)"
        />
      </View>
    );
  }
  // 實(shí)現(xiàn)在這里借小時(shí)
  get_hour() {
    var hu=this.state.hour; //獲取分鐘
    if (hu>0) { //分鐘不為0厅各,則直接借走1分鐘
      hu--; //分鐘減一
      this.setState({hour:hu}); //更改分鐘狀態(tài)
      return 1; //借走一分鐘
    }
    else if (hu==0) { //分鐘為0,從小時(shí)哪里借
      this.setState({hour:'00'}); //更改分鐘狀態(tài)
      return 0;
    }
  }
  // 實(shí)現(xiàn)在這里借分鐘
  get_minutes() {
    var mt=this.state.minutes; //獲取分鐘
    if (mt>0) { //分鐘不為0预柒,則直接借走1分鐘
      mt--; //分鐘減一
      this.setState({minutes:mt}); //更改分鐘狀態(tài)
      return 1; //借走一分鐘
    }
    else if (mt==0) { //分鐘為0队塘,從小時(shí)哪里借
      var get_hu=this.get_hour();
      if (get_hu==1) { //借到了
        this.setState({minutes:59}); //更改分鐘狀態(tài)
        return 1;
      }
      else{
        this.setState({minutes:'00'}); //沒借到,更改分鐘狀態(tài)
        return 0;
      }
    }
  }
  // 計(jì)時(shí)函數(shù)
  countTime(){
    this._timer=setInterval(()=>{
      var ct=this.state.seconds; //獲取秒
      if (ct>0) { //如果秒大于0宜鸯,則執(zhí)行減1
        ct--;
        this.setState({seconds:ct}); //更改秒的狀態(tài)
      }
      else if (ct==0) { // 秒為0憔古,去借分鐘
        var get_mt=this.get_minutes();
        if (get_mt==1) { //借分鐘成功
          ct=59;
          this.setState({seconds:ct}); //將秒設(shè)置為59
        }
        else if (get_mt==0) { //沒借到分鐘,說明計(jì)時(shí)結(jié)束
          this._timer&&clearInterval(this._timer);
        }
      }
    },1000);
  }
}
AppRegistry.registerComponent('Login', () => Login);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末淋袖,一起剝皮案震驚了整個(gè)濱河市投放,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌适贸,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件涝桅,死亡現(xiàn)場離奇詭異拜姿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)冯遂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門蕊肥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蛤肌,你說我怎么就攤上這事壁却。” “怎么了裸准?”我有些...
    開封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵展东,是天一觀的道長。 經(jīng)常有香客問我炒俱,道長盐肃,這世上最難降的妖魔是什么爪膊? 我笑而不...
    開封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮砸王,結(jié)果婚禮上推盛,老公的妹妹穿的比我還像新娘。我一直安慰自己谦铃,他們只是感情好耘成,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著驹闰,像睡著了一般瘪菌。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上疮方,一...
    開封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天控嗜,我揣著相機(jī)與錄音,去河邊找鬼骡显。 笑死疆栏,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的惫谤。 我是一名探鬼主播壁顶,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼溜歪!你這毒婦竟也來了若专?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤蝴猪,失蹤者是張志新(化名)和其女友劉穎调衰,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體自阱,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡咱士,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年系宜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蝉揍。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片啃炸。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖加派,靈堂內(nèi)的尸體忽然破棺而出叫确,到底是詐尸還是另有隱情,我是刑警寧澤芍锦,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布竹勉,位于F島的核電站,受9級(jí)特大地震影響醉旦,放射性物質(zhì)發(fā)生泄漏饶米。R本人自食惡果不足惜桨啃,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望檬输。 院中可真熱鬧照瘾,春花似錦、人聲如沸丧慈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽逃默。三九已至鹃愤,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間完域,已是汗流浹背软吐。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留吟税,地道東北人凹耙。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像肠仪,于是被迫代替她去往敵國和親肖抱。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理异旧,服務(wù)發(fā)現(xiàn)意述,斷路器,智...
    卡卡羅2017閱讀 134,656評(píng)論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,129評(píng)論 25 707
  • 國家電網(wǎng)公司企業(yè)標(biāo)準(zhǔn)(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報(bào)批稿:20170802 前言: 排版 ...
    庭說閱讀 10,970評(píng)論 6 13
  • 點(diǎn)飲料要點(diǎn)帶吸管的 或者攪拌棒 如此可以免于沉浸于無話可說
    AnnaSun0705閱讀 133評(píng)論 0 1
  • 圖片發(fā)自簡書App 大撒把 2017年9月吮蛹,miss hou重新教會(huì)我騎自行車荤崇。 通過開題答辯的當(dāng)天晚上,我倆騎著...
    叁肆伍閱讀 245評(píng)論 0 1