标签导航:

ant design list组件嵌套collapse组件时,如何解决标题显示异常问题?

Ant Design List和Collapse组件嵌套导致标题显示异常的解决方法

在Ant Design框架中,List组件与Collapse组件嵌套使用时,如果Collapse组件的子项为空,可能会出现标题显示异常的问题。本文将分析此问题并提供解决方案。

问题描述:

在PC端项目中,使用Ant Design的List组件,并在renderItem函数中嵌套Collapse组件。当item.children数组为空时,Collapse组件的标题显示不正确。

问题代码示例:

以下代码片段展示了问题所在:

<Collapse
  key={item.id}
  title={item.title}
  expandIconPosition="end"
  ghost
  showArrow={item.children.length} // 问题所在
>
  {item.children.map((child) => (
    <div
      key={child.id}
      onClick={() => {
        handleHelpInfo(child);
      }}
      style={{ cursor: 'pointer', marginBottom: 10, background: token.bgcolorPrimary, padding: 4 }}
    >
      {child.title}
    </div>
  ))}
</Collapse>

当item.children.length为0时,showArrow属性的值也为0,这并非Collapse组件期望的布尔值,导致标题显示异常。

问题解决:

问题的根本原因在于showArrow属性的值类型错误。 解决方法是将item.children.length转换为布尔值。可以使用双感叹号!!操作符:

showArrow={!!item.children.length}

这样,当item.children.length为0时,showArrow的值将为false,Collapse组件会正确隐藏箭头,从而解决标题显示异常的问题。

通过简单的代码修改,即可有效解决Ant Design List和Collapse组件嵌套时出现的标题显示异常问题,确保界面显示的正确性。