在 React 中,数据传递通常是自上而下的,也就是父组件把数据通过 props
传递给子组件,子组件无法直接修改父组件的数据。
const Parent = () => {
const user = { name: "John", age: 24 };
return ;
};
const Child = ({ user }) => {
return (
姓名: {user.name}
年龄: {user.age}
);
};
问题不大,看起来很简单,对吧?
但如果子组件需要修改父组件的数据,就必须通过回调函数,让子组件把新的数据“反向”传回父组件,让父组件更新数据。
const Parent = () => {
const [user, setUser] = useState({ name: "John", age: 24 });
// 让子组件调用这个方法来修改 user
const updateUser = (newName) => {
setUser({ ...user, name: newName });
};
return ;
};
const Child = ({ user, updateUser }) => {
return (
姓名: {user.name}
);
};
这样,点击按钮后,John
就会变成 Alice
,但这还不算太糟糕。
真正的问题是:如果有很多层嵌套怎么办?
如果 Child
不是直接在 Parent
里面,而是嵌套了好几层,每一层都要手动传 props
,就会变得非常痛苦。
const Parent = () => {
const [user, setUser] = useState({ name: "John", age: 24 });
const updateUser = (newName) => {
setUser({ ...user, name: newName });
};
return ;
};
// 一层又一层地传递 props...
const Level1 = ({ user, updateUser }) => ;
const Level2 = ({ user, updateUser }) => ;
const Level3 = ({ user, updateUser }) => ;
const Level4 = ({ user, updateUser }) => (
姓名: {user.name}
);
问题:
props
传递,代码变得冗长且难以维护。useContext
来救场!React 提供了 useContext
,它就像一个全局数据仓库,可以让任何组件直接访问数据,而不需要层层 props
传递。
import { createContext, useState } from "react";
// 1. 创建 Context
const UserContext = createContext();
// 2. 创建 Provider 组件
const UserProvider = ({ children }) => {
const [user, setUser] = useState({ name: "John", age: 24 });
const updateUser = (newName) => {
setUser({ ...user, name: newName });
};
return (
{children} {/* 这里的 children 让所有子组件都能访问这个 Context */}
);
};
export { UserContext, UserProvider };
useContext
读取数据import { useContext } from "react";
import { UserContext } from "./UserContext";
const UserProfile = () => {
const { user, updateUser } = useContext(UserContext);
return (
姓名: {user.name}
);
};
export default UserProfile;
App.js
里包裹 Providerimport React from "react";
import { UserProvider } from "./UserContext";
import UserProfile from "./UserProfile";
const App = () => {
return (
);
};
export default App;
useContext
很强大?props
传递,所有组件都能直接访问数据。props
变化导致所有中间组件都重新渲染。传统数据传递方式(props
)
props drilling
让代码变得难以维护。useContext
方式
props
层层传递。最佳实践
props
即可。useContext
来简化代码。 现在,你可以摆脱“数据传递地狱”,用 useContext
让 React 代码更清爽!