如何在 React 中渲染多个模态?
我需要渲染多种模态,但模态的数量未固定,并且取决于属性audios
进入的对象。我当前使用MUI模式,
这是使用的变量:
const [open, setOpen] = useState(false);
const handleOpen = () => setOpen(true);
const handleClose = () => setOpen(false);
这就是方式。我试图渲染模式。当前,单击“视图”后打开的模态仅显示audios
的最后一个值,无论我单击哪个“视图”按钮,
{audios.map((a) => (
<Grid item container justifyContent="flex-end">
<Button
onClick={handleOpen}
sx={{
color: 'blue',
marginTop: '0.6rem',
}}
>
View
</Button>
<Modal
open={open}
onClose={handleClose}
>
<Box
sx={{
position: 'absolute' as 'absolute',
top: '50%',
left: '50%',
p: 4,
}}
>
<Typography color='white'>{a.name}</Typography>
</Box>
</Modal>
</Grid>
))}
是否可以在每个模态上具有单独的状态?
I need to render multiple modals but the number of modals are not fixed and depend on property audios
of the object coming in. I'm currently using the mui modal
This is the variables used:
const [open, setOpen] = useState(false);
const handleOpen = () => setOpen(true);
const handleClose = () => setOpen(false);
And this is how I attempt to render the modals. Currently, the modal that opens after clicking 'view' only shows the last value in audios
no matter which 'View' button I click on
{audios.map((a) => (
<Grid item container justifyContent="flex-end">
<Button
onClick={handleOpen}
sx={{
color: 'blue',
marginTop: '0.6rem',
}}
>
View
</Button>
<Modal
open={open}
onClose={handleClose}
>
<Box
sx={{
position: 'absolute' as 'absolute',
top: '50%',
left: '50%',
p: 4,
}}
>
<Typography color='white'>{a.name}</Typography>
</Box>
</Modal>
</Grid>
))}
Is there way to have separate state for open and close for each modal?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
也许就像这样
maybe just like this
我认为您应该将“打开”状态放在模态组件中,以这种方式,每个模态都有自己的状态。
I think u should put the 'open' state in the Modal component , by this way every Modal have their own state .