我有一个StatusContext
这样命名的上下文:
export const statusCtxInit = {
open: false,
toggleOpen() {
this.open = !this.open;
}
};
const StatusContext = React.createContext(statusCtxInit);
export default StatusContext
整个应用程序与提供者一起包装:
// ...
<StatusContext.Provider value={statusCtxInit}>
// ...
要使用我useContext
在 FC 中使用的上下文的值,它会在我获得值时起作用。
function MyComp() {
const status = useContext(StatusContext);
return (
<div>
{status.open
? `It's Open`
: `It's Closed`}
<button onClick={() => status.toggleOpen()}>
Toggle
</button>
</div>
)
}
export default MyComp
另一方面,我也想通过调用来更改上下文,toggleOpen
但是它不能按我的意愿工作。实际上值改变但不影响MyComp
.
我做错了什么?我该怎么办?