mac*_*ost 6 ternary jsx reactjs
通常,如果你有类似的东西:
<SomeComponent foo={bar} />
Run Code Online (Sandbox Code Playgroud)
您可以使用三元组使其成为可选项:
{bar ? <SomeComponent foo={bar} /> : null}
Run Code Online (Sandbox Code Playgroud)
但是,如果您开始使用的块包含一个组件加上一些文本(单个空格)和一个变量,例如:
<SomeComponent foo={bar} /> {foobar}
Run Code Online (Sandbox Code Playgroud)
将它括在括号中是行不通的:
{bar ? (<SomeComponent foo={bar} /> {foobar}) : null}
Run Code Online (Sandbox Code Playgroud)
事实上,我发现使其工作的唯一方法是将所有内容包装在另一个元素中:
{bar ? <span><SomeComponent foo={bar} /> {foobar}</span> : null}
Run Code Online (Sandbox Code Playgroud)
有没有其他方法告诉React:
<SomeComponent foo={bar} /> {foobar}
Run Code Online (Sandbox Code Playgroud)
是一个离散的块,所以我可以在三元组中使用它(在JS内部,而不是JSX,逻辑)...而不添加无意义的包装元素?
曾经有两种次优的方法来实现这一目标:
使用数组,需要向React元素添加键:
{bar ? [<SomeComponent key="1" foo={bar} />, " ", foobar] : null}
Run Code Online (Sandbox Code Playgroud)但是使用React 16.2.0+,您可以使用改进的片段:
{bar ? <React.Fragment><SomeComponent foo={bar} /> {foobar}</React.Fragment> : null}
Run Code Online (Sandbox Code Playgroud)
或者,更好的是,您可以使用简写语法:
{bar ? <><SomeComponent foo={bar} /> {foobar}</> : null}
Run Code Online (Sandbox Code Playgroud)
片段不会产生额外的容器元素.
| 归档时间: |
|
| 查看次数: |
1029 次 |
| 最近记录: |