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

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

為什么當上下文值更新時我的上下文不更新?

為什么當上下文值更新時我的上下文不更新?

慕桂英3389331 2022-12-22 13:02:38
所以我在我的 Gatsby 應用程序(基本上是用 React 編寫的)中使用 React 的上下文 API 來處理用戶身份驗證。我有兩個使用該上下文的組件:dashboard和navBar。當我嘗試登錄和注銷時,我的navBar行為會根據我的不同而有所不同userContext,但我dashboard不會回應。它是否與結構有關,例如navBar直接“子級”到layout,但dashboard不是?我假設不是,畢竟,這就是為什么我使用contextAPIthen just pass 一個普通的道具。以下是代碼://layout.jsimport React, { useContext, useState, createContext } from "react"import Navbar from "../components/navBar"import {monitorAuth} from "../firebase/firebaseService"export const UserStateContext = createContext(null)export const SetUserContext = createContext()const Layout = ({ children }) => {  const [user, setUser] = useState()  console.log(user)  monitorAuth(setUser)// everytime a layout component renders, it will grab a user if it is logged inthen setUser, then I will use it in the context  return (    <>      <UserStateContext.Provider value={user}>        <SetUserContext.Provider value={setUser}>          <div>            <SEO />            <Navbar />            <main>{children}</main>          </div>        </SetUserContext.Provider >      </UserStateContext.Provider>    </>  )}export default Layoutimport React, { useState, useContext } from "react"import AppBar from "@material-ui/core/AppBar"import { signOut } from "../firebase/firebaseService"import {UserStateContext} from "./layout"export default function NavBar() {  const user = useContext(UserStateContext)  console.log(user) // when I log in/ log out, it will console.log the right user status, user/null  const renderMenu = () => {    return (    <>      {user? (      <>      <Button onClick={signOut}>Sign Out</Button>      <Button>My profile</Button>       </>)     :<Button>Sign In</Button> }    </>    )  }  return (    <AppBar position="static" className={classes.root}>        ...        {renderMenu()}        ...  </AppBar>  )}
查看完整描述

1 回答

?
眼眸繁星

TA貢獻1873條經驗 獲得超9個贊

它不起作用的原因是因為您的<Dashboard>組件不是上下文提供程序的子項。如果你使用 React devtools,你會看到組件樹看起來像


<Dashboard>

  <Layout>

    <UserStateContext.Provider>

      <SetUserContext.Provider>

        ...

      </SetUserContext.Provider> 

    </UserStateContext.Provider> 

  </Layout>

</Dashboard>

當上下文值發生變化時,它會在其子樹中查找組件useContext。然而,Dashboard不是孩子,是父母!


如果你想遵循這種模式,一個解決方案可能是創建一個父組件Dashboard并將上下文放在那里。


查看完整回答
反對 回復 2022-12-22
  • 1 回答
  • 0 關注
  • 82 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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