微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

React settimeout 函数导致页面反复刷新

如何解决React settimeout 函数导致页面反复刷新

我和我的朋友正在尝试创建一个 React 应用程序。在这个场景中,我们想要找出当前登录用户,然后发送一个 post 请求来确定与他们在同一个“房间”中的每个人,并在页面加载时将其显示在应用程序上。我们将数据作为数组发回。虽然当我们 console.log 我们的“响应”时,我们会得到多个输出。此外,当我们尝试执行 setRoomies 时,我们会收到对服务器的不间断请求。

下面我提供了我们的 React、服务器和控制台代码

function Dashboard() {
    const [email,setEmail] = useState('');
    const [password,setPassword] = useState('');
    const [user,setUser] = useState('');
    const [roomKey,setRoomKey] = useState('')
    const [roomies,setRoomies] = useState('')

    setTimeout(function () {
        const currUser = JSON.parse(localStorage.getItem('user'));
        if (currUser) {
            setEmail(currUser.email);
            setUser(currUser.name);
            setRoomKey(currUser.roomKey)
        } else {
            setUser(null)
        }

    },10);


    const payload = {
        roomKey: roomKey
    }
    setTimeout(async function () {
        const response = await axios({
            url: 'http://localhost:4000/api/dashboard',method: 'post',data: payload
        })

        // setRoomies(response.data.roommates)
        console.log(response.data.roommates)
    },10)
userRouter.post('/dashboard',async function (req,res) {
    console.log(req.body)
    const sendKey = req.body.roomKey

    user.find({ roomKey: sendKey },await function (err,foundMates) {
        console.log(foundMates)
        if (err) {
            res.send({
                token: USER_LOGIN_FAIL
            })
        } else {
            console.log(foundMates);
            res.send({
                token: USER_LOGIN_SUCCESS,roommates: foundMates,})
        }
    })
})

console

解决方法

您不应该那样使用 setTimeout。相反,您应该使用 useEffect 来实现您想要的。可能需要一些改变,但想法是做这样的事情

useEffect(() => {
       const currUser = JSON.parse(localStorage.getItem('user'));
       if (currUser) {
          setEmail(currUser.email);
          setUser(currUser.name);
          setRoomKey(currUser.roomKey)
       } else {
                setUser(null)
            }
    
       },[]);
    
useEffect(() => {
        if(!roomKey) {
          return;
        }
    
        const payload = {
            roomKey: roomKey
        }
        async function getInfo() {
            const response = await axios({
                url: 'http://localhost:4000/api/dashboard',method: 'post',data: payload
            })
    
            // setRoomies(response.data.roommates)
            console.log(response.data.roommates)
        }
        getInfo();
},[roomKey]);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。