createContext
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, especificanull
. 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 auseContext(SomeContext)
dentro del proveedor recibe elvalor
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 queuseContext()
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.