我正在使用 context.provider usecontext reacthook 来显示一个对话框。我把这个设置在MainComponent周围。对于 context.provider 的值属性,我获取错误类型 {setDialogOpen(Open: boolean) => void} 不可分配给布尔类型。
我想做什么?我想在用户单击主页或书籍组件中的按钮时显示对话框。单击对话框中的隐藏按钮,对话框不应打开。
下面是我的代码,
function MainComponent() {
const DialogContext = React.createContext(false);
let [showDialog, setShowDialog] = React.useState(false);
return (
<DialogContext.Provider value={{
setDialogOpen: (open: boolean) => setShowDialog(open)}}>//get error
{showDialog && <Dialog DialogContext={DialogContext}/>
<Route
path="/items">
<Home DialogContext={DialogContext}/>
</Route>
<Route
path="/id/item_id">
<Books DialogContext={DialogContext}/>
</Route>
</DialogContext.Provider>
)
}
function Home({DialogContext} : Props) {
const dialogContext= React.useContext(DialogContext);
const handleClick = (dialogContext: any) {
dialogContext.setDialogOpen(true);
}
return (
<button onClick={handleClick(dialogContext)}>button1</button>
)
}
function Books({DialogContext} : Props) {
const dialogContext= React.useContext(DialogContext);
const handleClick = (dialogContext: any) {
dialogContext.setDialogOpen(true);
}
return (
<button onClick={handleClick(dialogContext)}>button2</button>
)
}
function Dialog({DialogContext}: Props) {
return(
<div>
//sometext
<button> hide</button>
</div>
)
}
我尝试了如下方法,
return (
<DialogContext.Provider value={{
setShowDialog(open)}}>//still get a error
{showDialog && <Dialog DialogContext={DialogContext}/>
)
有人可以帮我解决这个问题,或者提供更好的方法来显示使用usecontext hook单击主页和书籍组件中的按钮的对话框。谢谢。
繁星coding
相关分类