亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何暫停渲染,直到在反應中獲取數據

如何暫停渲染,直到在反應中獲取數據

汪汪一只貓 2023-09-28 16:39:59
我是新來反應的,我遇到了這個問題。import React from "react";import firebase from "firebase";import fire from "./firebase"import { Route, BrowserRouter as Router, Switch, Redirect, useHistory, NavLink } from 'react-router-dom';import Header from "./header"import Nav from "./nav"import data from "./data"function Home(){    let userID;    let userName;    let logg;    const history = useHistory();    firebase.auth().onAuthStateChanged((user)=>{        if(user){            userID = user.uid        }else{            history.push("/login")        }     })        return(        <>        <Header />        <Nav />        <div id = "home" className ="main">            <div class = "headingCont">                <h1>This is home</h1>                <NavLink to = {"users/"+userID}><p>Your Profile</p></NavLink>            </div>        </div>        </>    )    }export default Home我正在從 firebase 獲取用戶 id,但它會快速渲染 jsx,因此 userID 的值仍然未定義。因此,當我單擊“您的個人資料”時,它會轉到 user/undefined 而不是 user/“用戶 ID”,我該如何修復它?
查看完整描述

1 回答

?
慕哥9229398

TA貢獻1877條經驗 獲得超6個贊

您應該使用狀態而userId不是范圍變量。


const [userID, setUserID] = useState(null)

firebase.auth().onAuthStateChanged((user) => {

  if (user) {

    setUserID(user.uid)

  } else {

    history.push('/login');

  }

});


查看完整回答
反對 回復 2023-09-28
  • 1 回答
  • 0 關注
  • 98 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號