Skip to content
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
82 changes: 82 additions & 0 deletions 02-fundamentos-react/04-datos-globales.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,8 @@ Ahí entran los estados globales.

# Opción 1: Context de React

_.\src\01-Context-React.tsx_

```tsx
import React, { createContext, useContext, useState } from "react";

Expand Down Expand Up @@ -84,6 +86,86 @@ export const useNombre = () => {
};
```

_.\src\01-Context-React.tsx_

```diff
import React, { createContext, useContext, useState } from "react";

interface NombreContextValue {
nombre: string;
setNombre: (nuevoNombre: string) => void;
}

const NombreContext = createContext<NombreContextValue | null>(null);

interface Props {
children: React.ReactNode;
}

export const NombreProvider = ({ children }: Props) => {
const [nombre, setNombre] = useState("Pepe");

return (
<NombreContext.Provider value={{ nombre, setNombre }}>
{children}
</NombreContext.Provider>
);
};

export const useNombre = () => {
const context = useContext(NombreContext);

if (context === null) {
throw new Error("useNombre debe usarse dentro de NombreProvider");
}

return context;
};

+ const Header = () => {
+ return <header style={{ background: "#e0f0ff", padding: "8px" }}>Header</header>;
+ };
+
+ const Body = () => {
+ const { nombre, setNombre } = useNombre();
+ return (
+ <main style={{ padding: "8px" }}>
+ <p>Body: {nombre}</p>
+ <input value={nombre} onChange={(e) => setNombre(e.target.value)} />
+ </main>
+ );
+ };
+
+ const Footer = () => {
+ return <footer style={{ background: "#e0f0ff", padding: "8px" }}>Footer</footer>;
+ };
+
+ export const ContextDemo = () => (
+ <NombreProvider>
+ <Header />
+ <Body />
+ <Footer />
+ </NombreProvider>
+ );
```

__

```diff
+ import { ContextDemo } from "./01-Context-React"

function App() {

return (
<>
+ <ContextDemo />
</>
)
}

export default App
```

---

# Opción 2: Zustand
Expand Down