有很多列表项目,我想在他们外面给他们添加一层,给他们整体添加一个外边框,然后把外面这层外边框写成一个组件,但是当子组件返回为空的时候回出现一些问题
最开始是这样
import Item from './Item';
function foo(){
return (
<>
<Item/>
<Item/>
<Item/>
<Item/>
<Item/>
<Item/>
</>
)
}
现在需要给他们加一层外壳
import Item from './Item';
import Wraper from "./Wraper';
function foo(){
return (
<>
<Wraper>
<Item/>
<Item/>
<Item/>
</Wraper>
<Wraper>
<Item/>
<Item/>
<Item/>
</Wraper>
</>
)
}
这个Wraper
组件有一些外边距和内边距, 如果Wraper
组件里面的所有Item
组件都返回null
| undefined
那么这个Wraper
组件就不应该渲染, 在Wraper
组件里面使用React.Children.count
计算出来的值永远都会3,因为这些子组件即便返回null
| undefained
也是有效的子组件
所以如何才能准确计算Wraper
组件实际渲染的子组件的数量 ? ? ?