Почему 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.

0 ответов

Другие вопросы по тегам