我有一个 WebGL/React 项目,它在点击时从模拟数据生成用户列表。
我希望这个内容出现在手风琴中,因为在我认为我会使用他们的扩展面板之前,我对材料 ui 有很好的经验。
它直接从演示页面运行良好,但是如果我想映射我的用户数据库并用它填充扩展面板,它似乎摆脱了方便的功能。
我希望默认打开第一个扩展面板,然后当您单击一个面板时,关闭任何其他面板,这是示例中的默认行为。
当我传入道具时
<ExpansionPanel
square
expanded={expanded === "panel1"}
onChange={handleChange("panel1")}
>
<ExpansionPanelSummary
aria-controls="panel1d-content"
id="panel1d-header"
>
{props.country}
</ExpansionPanelSummary>
<ExpansionPanelDetails>{props.children}</ExpansionPanelDetails>
</ExpansionPanel>
</div>
然后在这里使用它......
{users &&
users.map(user => (
<Accordion title={user.name} key={user.name}>
<div className="overlay-container">
<div className="overlay overlay-anim">
<div className="overlay-content-container">
<div className="name-container">
<h1 key={user.id} className="user_name">
{user.name}
</h1>
</div>
</div>
</div>
</div>
</Accordion>
))}
它默认打开所有面板,当一个面板处于活动状态时不会关闭其他面板。(同样不是真实数据,而且 gif 使它有点错误,但我无法生成示例,因为代码库太大)。
有人会对如何实现这一目标有一些想法或例子吗?
编辑
根据下面的建议,在映射函数中添加了一个 id 并调整了扩展组件,不幸的是得到了相同的效果/问题
const [expanded, setExpanded] = React.useState("panel" + props.id);
const handleChange = panel => (event, newExpanded) => {
setExpanded(newExpanded ? panel : false);
};
return (
<div>
<ExpansionPanel
expanded={expanded === "panel" + props.i}
onChange={handleChange("panel" + props.i)}
>
<ExpansionPanelSummary
aria-controls={"panel" + props.id + "d" + "-content"}
id={"panel" + props.id + "d" + "-header"}
>
{props.country}
</ExpansionPanelSummary>
<ExpansionPanelDetails>{props.children}</ExpansionPanelDetails>
</ExpansionPanel>
</div>
);
}```

