createContext te permite crear un contexto que los componentes pueden proporcionar o leer.

const SomeContext = createContext(defaultValue)

Uso

Creando un contexto

El contexto permite que los componentes pasen información en profundidad sin pasar props explícitamente.

Llama a createContext fuera de cualquier componente para crear uno o más contextos.

import { createContext } from 'react';

const ThemeContext = createContext('light');
const AuthContext = createContext(null);

createContext retorna un objeto context. Los componentes pueden leer el contexto pasándolo a useContext():

function Button() {
const theme = useContext(ThemeContext);
// ...
}

function Profile() {
const currentUser = useContext(AuthContext);
// ...
}

De forma predeterminada, los valores que reciben serán los valores predeterminados que se han especificado al crear los contextos. Sin embargo, esto no es útil porque los valores predeterminados nunca cambian.

El contexto es útil porque puede proporcionar otros valores dinámicos a sus componentes:

function App() {
const [theme, setTheme] = useState('dark');
const [currentUser, setCurrentUser] = useState({ name: 'Taylor' });

// ...

return (
<ThemeContext.Provider value={theme}>
<AuthContext.Provider value={currentUser}>
<Page />
</AuthContext.Provider>
</ThemeContext.Provider>
);
}

Ahora el componente Page y cualquier componente dentro de él, sin importar cuán profundo sea, “verán” los valores de contexto dados. Si los valores del contexto dados cambian, React volverá a renderizar los componentes leyendo el contexto también.

Aprende más sobre leer y proporcionar un contexto, ver más ejemplos.


Importación y exportación de contexto desde un archivo

A menudo, los componentes de diferentes archivos necesitarán acceso al mismo contexto. Por eso es común declarar contextos en un archivo separado. Luego puedes usar la declaración export para hacer que el contexto esté disponible para otros archivos:

// Contexts.js
import { createContext } from 'react';

export const ThemeContext = createContext('light');
export const AuthContext = createContext(null);

Los componentes declarados en otros archivos pueden usar la declaración import para leer o proveer un contexto:

// Button.js
import { ThemeContext } from './Contexts.js';

function Button() {
const theme = useContext(ThemeContext);
// ...
}
// App.js
import { ThemeContext, AuthContext } from './Contexts.js';

function App() {
// ...
return (
<ThemeContext.Provider value={theme}>
<AuthContext.Provider value={currentUser}>
<Page />
</AuthContext.Provider>
</ThemeContext.Provider>
);
}

Esto funciona de manera similar a la importación y exportación de componentes.


Referencia

createContext(defaultValue)

Puedes llamar a createContext fuera de cualquier componente para crear un contexto.

import { createContext } from 'react';

const ThemeContext = createContext('light');

Parámetros

  • defaultValue: El valor que desees que tenga el contexto cuando no hay un proveedor de contexto coincidente en el árbol sobre el componente que lee el contexto. Si no tiene ningún valor predeterminado significativo, especifica null. El valor predeterminado se entiende como una reserva de “último recurso”. Es estático y nunca cambia con el tiempo.

Retorna

createContext devuelve un objeto de contexto.

El objeto de contexto en sí no contiene ninguna información. Representa qué contexto pueden leer o proporcionar otros componentes. Por lo general, utilizará SomeContext.Provider en los componentes anteriores para especificar el valor de contexto y llamará a useContext(SomeContext) en los componentes siguientes para leerlo. El objeto de contexto tiene algunas propiedades:

  • SomeContext.Provider Te permite proporcionar el valor de contexto a los componentes.
  • SomeContext.Consumer Es una forma alternativa y poco utilizada de leer el valor del contexto..

SomeContext.Provider

Envuelve tus componentes en un proveedor de contexto para especificar el valor de este contexto para todos los componentes dentro:

function App() {
const [theme, setTheme] = useState('light');
// ...
return (
<ThemeContext.Provider value={theme}>
<Page />
</ThemeContext.Provider>
);
}

Props

  • value: El valor que desees pasar a todos los componentes que leen este contexto dentro de este proveedor, sin importar cuán profundo sea. El valor de contexto puede ser de cualquier tipo. Un componente que llama a useContext(SomeContext) dentro del proveedor recibe el valor del proveedor de contexto correspondiente más interno que se encuentra arriba.

SomeContext.Consumer

Antes de que existiera useContext, había una forma más antigua de leer el contexto:

function Button() {
// 🟡 Forma antigua (no recomendado)
return (
<ThemeContext.Consumer>
{theme => (
<button className={theme} />
)}
</ThemeContext.Consumer>
);
}

Aunque esta forma aún funciona, el código recién escrito debería leer el contexto con useContext() en su lugar:

function Button() {
// ✅ Forma recomendada
const theme = useContext(ThemeContext);
return <button className={theme} />;
}

Props

  • children: Una función. React llamará a la función que pase con el valor de contexto actual determinado por el mismo algoritmo que useContext() y generará el resultado que devuelve de esta función. React también volverá a ejecutar esta función y actualizará la interfaz de usuario siempre que el contexto pasado desde los componentes principales haya cambiado.

Solución de problemas

No puedo encontrar la manera de cambiar el valor del contexto

Un código como este especifica el valor de contexto predeterminado:

const ThemeContext = createContext('light');

Este valor nunca cambia. React solo usa este valor como respaldo si no puede encontrar un proveedor coincidente arriba.

Para hacer que el contexto cambie con el tiempo, agrega componentes de estado y ajusta un proveedor de contexto.