一次只展开一个折叠 (material-ui)-React

我有表,我可以扩展折叠材料-ui。一切都很完美。

我有表,我可以扩展折叠材料-ui。一切都很完美。

但是有一件事我想更新,当我点击展开时,一次只打开一个展开折叠。

const InvoiceInfo = ({el}) => {
const [open, setOpen] = React.useState(false)
}
function handleExpand() {
    setOpen(!open)
  }
return (
<>
<TableRow key={el.id}>
    <TableCell>
       {el.name}
    </TableCell>
    <TableCell>
        <IconButton onClick={handleExpand}>
                {open ? (
                  <KeyboardArrowUp fontSize="large" />
                ) : (
                  <KeyboardArrowDown fontSize="large" />
                )}
         </IconButton>
    </TableCell>
</TableRow>
{
<TableRow>
    <Collapse in={open} timeout="auto" unmountOnExit>
        <div>
           EXPAND ROW
        </div>
    </Collapse>
</TableRow>
}
</>
)

上面是我的代码看起来像。

任何建议对我来说都是非常有意义的。

1

您可以根据数组的索引或给定的数字 / 值使用简单的状态:

const [isOpenCollapse, setIsOpenCollapse] = useState(null);
const handleOpen = (clickedIndex) => {
  if (isOpenCollapse === clickedIndex) {
    setIsOpenCollapse(null);
  } else {
    setIsOpenCollapse(clickedIndex);
  }
};
[...]
return (
  <List>
    {arr.map((elm, index) => {
      return (
        <>
          <ListItem key={elm.ID} onClick={() => handleOpen(index)} id="listItem">
            {isOpenCollapse === index ? <ExpandLess /> : <ExpandMore />}
            <Box>
              <Typography>{elm.label}</Typography>
            </Box>
          </ListItem>
          <Collapse in={isOpenCollapse === index} timeout="auto" unmountOnExit>
            <p>PUT SOMETHING HERE</p>
          </Collapse>
        </>
      );
    })}
  </List>;
)

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(65)
如何使用 CSS制作具有固定标题的可滚动表
上一篇
我在我的常规图表中使用了TrueStrength指数我可以在tradingview的cryptoscreener中使用它吗
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 98 97
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 59 34
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 16 94
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 50 95
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 99 23
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 42 15
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 98 89
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 38 55

发表评论

登录 后才能评论

评论列表(59条)