首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用React制作的数字时钟不工作

使用React制作的数字时钟不工作
EN

Stack Overflow用户
提问于 2022-06-21 05:43:49
回答 1查看 99关注 0票数 -1

我在学Udemy的反应。当我使用旧的React版本时,我的代码正在工作,但是对于新的18.1版本,它不起作用。我正试图建立一个简单的数字时钟,但遗憾的是,没有工作。有人帮忙吗?

代码语言:javascript
复制
import React, { useState } from "react";
import logo from './logo.svg';
import './App.css';
function App() {
  setInterval(Time, 1000);
  const date = new Date();
  const time = date.toLocaleTimeString();
  const [uptime, funcTime] = useState(time)
  // event.preventDefault()
  
  function Time() {

    return (
      funcTime(time)
   )
  };
  return (
    <>
      <h1>TIME</h1>
      {uptime}
      {/* <button onClick={Time} type="submit">submit</button> */}
    </>

  )
}
export default App;
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-06-21 05:55:32

我已经将时间间隔移到useEffect,尝试如下

代码语言:javascript
复制
import React, { useState,useEffect } from "react";
import logo from './logo.svg';
import './App.css';

function App() {
  const date = new Date();
  const time = date.toLocaleTimeString();
  const [uptime, funcTime] = useState(time);

  useEffect(() => {
    const interval = setInterval(() => {
      const newTime = new Date().toLocaleTimeString();
      funcTime(newTime);
    }, 1000);

    return () => {
      clearInterval(interval);
    };
  }, [time]);
  // event.preventDefault()

  return (
    <>
      <h1>TIME</h1>
      {uptime}
      {/* <button onClick={Time} type="submit">submit</button> */}
    </>
  );
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72695863

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档