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组件嵌套时出现的标题显示异常问题,确保界面显示的正确性。