時間處理及倒計時

時間處理

可參考:https://blog.csdn.net/qq_36864205/article/details/110923888

import moment from 'moment';
new Date()  // Mon Mar 28 2022 11:20:05 GMT+0800 (GMT+08:00)
new Date().getTime()  // 1648437648080
new Date(1648437648080)  // Mon Mar 28 2022 11:20:48 GMT+0800 (GMT+08:00)
new Date(1900, 1, 1)  // Thu Feb 01 1900 00:00:00 GMT+0800 (GMT+08:00)
new Date('2022-03-11')  // Fri Mar 11 2022 08:00:00 GMT+0800 (GMT+08:00)
new Date('2022-03-11').getFullYear() // 2022
new Date('2022-03-11').getMonth() // 2
new Date('2022-03-11').getMonth() + 1 // 3
new Date('2022-03-11').getDate() // 11

moment(new Date())
moment(new Date()).format('YYYY-MM-DD')

時間比較

// IOS系統(tǒng)需要寫先處理兼容性問題
const examEndTime = this.examEndTime.replace(/-/g, '/')
const examStartTime = this.examStartTime.replace(/-/g, '/')
if (
   Date.parse(examEndTime) > new Date() &&
   new Date() > Date.parse(examStartTime)
) {}

倒計時【根據(jù)后端返回開始時間及new date當(dāng)前時間計算剩余時間】

import moment from 'moment';
// 倒計時
  const [countdown, setCountdown] = useState('0小時 0分 0秒');
  let outTimer: any;
  // 獲取模塊限時狀態(tài)
  const [timeSelect, setTimeSelect] = useState<any>(null);
  let timeleftNew = 0;
  useEffect(async () => {
      const result = await timeStateApi(scoreId);
      if (result) {
        const select = result.stateList[parseFloat(selectedMenu.id) - 1];
        setTimeSelect(select);
      } else {
        Toast.info('信息獲取失敗!', 1.5);
      }
  }, []);

  useEffect(() => {
    if (timeSelect) {
      // 倒計時
        const startTime = new Date(timeSelect.startTime).getTime();
        const nowTime = new Date().getTime();
        const endTime = startTime + timeSelect.limitTime * 1000;
        let timeDifference = endTime - nowTime * 1000;
        if (timeDifference > 0) {
          outTimer = setInterval(changeTime, 1000);
        } else {
          clearInterval(outTimer);
          setTimeOutShow(true);
        }
    }
    return () => {
      clearInterval(outTimer);
    };
  }, [timeSelect]);

  const changeTime = () => {
    const timeOutInfo = timeSelected.stateList[parseFloat(selectedMenu.id) - 1];
    const startTime = new Date(timeOutInfo.startTime).getTime();
    const nowTime = new Date().getTime();
    const endTime = startTime + timeOutInfo.limitTime * 1000;
    let timeDifference = endTime - nowTime * 1000;
    let d, h, m, s;
    if (timeDifference > 0) {
      d = Math.floor(timeDifference / 1000 / 60 / 60 / 24);
      h = Math.floor((timeDifference / 1000 / 60 / 60) % 24);
      m = Math.floor((timeDifference / 1000 / 60) % 60);
      s = Math.floor((timeDifference / 1000) % 60);
      d
        ? setCountdown(`$j3hvblx天 ${h}小時 ${m}分 ${s}秒`)
        : setCountdown(`${h}小時 ${m}分 ${s}秒`);
    } else {
      setCountdown(`0小時 0分 0秒`);
      clearInterval(outTimer);
      setTimeOutShow(true);
    }
  };

倒計時【根據(jù)后端返回剩余時間】

// 倒計時
  const [countdown, setCountdown] = useState('0小時 0分 0秒');
  let outTimer: any;
  // 獲取模塊限時狀態(tài)
  const [timeSelect, setTimeSelect] = useState<any>(null);
  let timeleftNew = 0;
  useEffect(async () => {
      const result = await timeStateApi(scoreId);
      if (result) {
        const select = result.stateList[parseFloat(selectedMenu.id) - 1];
        setTimeSelect(select);
      } else {
        Toast.info('信息獲取失敗!', 1.5);
      }
  }, []);

  useEffect(() => {
    if (timeSelect) {
      // 倒計時
        timeleftNew = timeSelect.timeLength;
        let timeDifference = timeleftNew;
        if (timeDifference > 0) {
          outTimer = setInterval(changeTime, 1000);
        } else {
          clearInterval(outTimer);
          setTimeOutShow(true);
        }
    }
    return () => {
      clearInterval(outTimer);
    };
  }, [timeSelect]);

  const changeTime = () => {
    let timeDifference = timeleftNew;
    let d, h, m, s;
    if (timeDifference > 0) {
      d = Math.floor(timeDifference / 60 / 60 / 24);
      h = Math.floor((timeDifference / 60 / 60) % 24);
      m = Math.floor((timeDifference / 60) % 60);
      s = Math.floor(timeDifference % 60);
      d
        ? setCountdown(`$bzlhlhj天 ${h}小時 ${m}分 ${s}秒`)
        : setCountdown(`${h}小時 ${m}分 ${s}秒`);
      timeleftNew = timeleftNew - 1;
    } else {
      setCountdown(`0小時 0分 0秒`);
      clearInterval(outTimer);
      setTimeOutShow(true);
    }
  };
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市狡恬,隨后出現(xiàn)的幾起案子珠叔,更是在濱河造成了極大的恐慌,老刑警劉巖弟劲,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件祷安,死亡現(xiàn)場離奇詭異,居然都是意外死亡兔乞,警方通過查閱死者的電腦和手機(jī)汇鞭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進(jìn)店門凉唐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人虱咧,你說我怎么就攤上這事熊榛。” “怎么了腕巡?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵玄坦,是天一觀的道長。 經(jīng)常有香客問我绘沉,道長煎楣,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任车伞,我火速辦了婚禮择懂,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘另玖。我一直安慰自己困曙,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布谦去。 她就那樣靜靜地躺著慷丽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鳄哭。 梳的紋絲不亂的頭發(fā)上要糊,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天,我揣著相機(jī)與錄音妆丘,去河邊找鬼锄俄。 笑死,一個胖子當(dāng)著我的面吹牛勺拣,可吹牛的內(nèi)容都是我干的奶赠。 我是一名探鬼主播,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼宣脉,長吁一口氣:“原來是場噩夢啊……” “哼车柠!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起塑猖,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤竹祷,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后羊苟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體塑陵,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年蜡励,在試婚紗的時候發(fā)現(xiàn)自己被綠了令花。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片阻桅。...
    茶點故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖兼都,靈堂內(nèi)的尸體忽然破棺而出嫂沉,到底是詐尸還是另有隱情,我是刑警寧澤扮碧,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布趟章,位于F島的核電站,受9級特大地震影響慎王,放射性物質(zhì)發(fā)生泄漏蚓土。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一赖淤、第九天 我趴在偏房一處隱蔽的房頂上張望蜀漆。 院中可真熱鬧,春花似錦咱旱、人聲如沸确丢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蠕嫁。三九已至,卻和暖如春毯盈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背病袄。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工搂赋, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人益缠。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓脑奠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親幅慌。 傳聞我的和親對象是個殘疾皇子宋欺,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,486評論 2 348

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