Dor*_*ian 2 authentication reactjs react-context
我想要一种使用 React Context 获取和获取当前用户的方法(不要将 props 传递给我的所有组件)
我尝试使用 React Context 但不明白如何实现const { currentUser, fetchCurrentUser } = useCurrentUser()文档中的类似内容。
Dor*_*ian 11
这是我为我的项目所做的:
// src/CurrentUserContext.js
import React from "react"
export const CurrentUserContext = React.createContext()
export const CurrentUserProvider = ({ children }) => {
const [currentUser, setCurrentUser] = React.useState(null)
const fetchCurrentUser = async () => {
let response = await fetch("/api/users/current")
response = await response.json()
setCurrentUser(response)
}
return (
<CurrentUserContext.Provider value={{ currentUser, fetchCurrentUser }}>
{children}
</CurrentUserContext.Provider>
)
}
export const useCurrentUser = () => React.useContext(CurrentUserContext)
Run Code Online (Sandbox Code Playgroud)
然后像这样使用它:
设置提供者:
// ...
import { CurrentUserProvider } from "./CurrentUserContext"
// ...
const App = () => (
<CurrentUserProvider>
...
</CurrentUserProvider>
)
export default App
Run Code Online (Sandbox Code Playgroud)
并在组件中使用上下文:
...
import { useCurrentUser } from "./CurrentUserContext"
const Header = () => {
const { currentUser, fetchCurrentUser } = useCurrentUser()
React.useEffect(() => fetchCurrentUser(), [])
const logout = async (e) => {
e.preventDefault()
let response = await fetchWithCsrf("/api/session", { method: "DELETE" })
fetchCurrentUser()
}
// ...
}
...
Run Code Online (Sandbox Code Playgroud)
完整的源代码可以在 github 上找到: https: //github.com/dorianmarie/emojeet
该项目可以在以下网址实时试用: http: //emojeet.com/
如果useContext返回undefined,那么您可能忘记了提供程序或者需要将您的提供程序向上移动。
| 归档时间: |
|
| 查看次数: |
7571 次 |
| 最近记录: |