Почему Context возвращает undefined для родительского компонента, но не для его дочерних компонентов?
Я могу получить значения из контекста в одном компоненте, но не в другом, который является его "родителем". Мой файл контекста:
import React, { useState } from 'react'
const Context = React.createContext()
const ContextProvider = ({ children }) => {
const [isConfiguring, setIsConfiguring] = useState(false)
return (
<Context.Provider value={{ isConfiguring, setIsConfiguring }}>
{children}
</Context.Provider>
)}
export { Context, ContextProvider }
В компоненте "Форма" я оборачиваю ContextProvider вокруг "Параметры".
...
return (
...
<ContextProvider>
<Options />
</ContextProvider>
...
)
В компоненте "Параметры" я не могу деструктурировать контекст, так как он возвращает "undefined".
const Options = () => {
const { isConfiguring, setIsConfiguring } = useContext(Context) //undefined
//TypeError: Cannot destructure property 'isConfiguring' of 'Object(...)(...)' as it is undefined.
const serviceElements = servicesList.map(service =>
<Service
name={service.name}
/>)
return (
...
{serviceElements}
)
...
)
}
Затем, к моему удивлению, Context работает внутри компонента "Сервис" (который находится внутри "Параметры").
const Service = (props) => {
const { isConfiguring } = useContext(Context) //works!!!
}
Итак, как я могу это исправить? В компоненте "Параметры" я попробовал сделать следующее:
const context = useContext(Context)
console.log(context) //undefined at first.
//when component renders, it logs '{isConfiguring: false, setIsConfiguring: ƒ}'
//It will log undefined when the component isn't on my screen (rendering).
//But when I go to the route where the component is at, it logs as
{isConfiguring: false, setIsConfiguring: ƒ}
//However, doing
console.log(context.isConfiguring) //TypeError: Cannot read property 'isConfiguring' of undefined
//even before the component is rendered.