gpt4 book ai didi

javascript - 在父组件中有条件地渲染子组件

转载 作者:行者123 更新时间:2023-11-29 20:32:48 24 4
gpt4 key购买 nike

我有一个父组件 DataTable,它有 Column 子组件。如果 prop 设置为 true,我想包含一个特定的 Column 子组件。我试过逻辑 && 和三元运算符。问题是我无法将任何 null 或未定义的值传递给 DataTable。当 this.props.hasMiddleName 为 false 时,逻辑 && 和三元运算符似乎提供 false、null 或未定义值作为 DataTable 的子项。我该如何修复此代码,以便在 this.props.hasMiddleName 为 false 时不传递任何虚假值?

<DataTable dataUrl={this.props.url}>
<Column Header={"First Name"} />
{ this.props.hasMiddleName &&
<Column Header={"Middle Name"} />
}
<Column Header={"Last Name"} />
</DataTable>

最佳答案

您应该在另一个函数中创建一个子数组。

renderChildren = () => {
let children = [<Column Header={"First Name"} />]
if(this.props.hasMiddleName) {
children.push(<Column Header={"Middle Name"} />)
}
children.push(<Column Header={"Last Name"} />)
return children
}

DataTable 中,您调用将呈现其子项的函数。

<DataTable dataUrl={this.props.url}>
{this.renderChildren()}
</DataTable>

关于javascript - 在父组件中有条件地渲染子组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57660738/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com