如果有!JSX 树将由组件返回。您可能已经注意到渲染输出中存在一些重复:
<li className="item">{name} ✔</li>
<li className="item">{name}</li>
两个条件分支都返回:<li className="item">...</li>
if (isPacked) {
return <li className="item">{name} ✔</li>;
}
return <li className="item">{name}</li>;
虽然这种重复是无害的,但它可能会使你的代码更难维护。如果要更改 ?你必须在代码中的两个地方执行此操作!在这种情况下,你可以有条件地包含一点 JSX,使你的代码更加 DRY。className
条件(三元)运算符 (? :
)
JavaScript 有一个紧凑的语法来编写条件表达式——条件运算符或“三元运算符”。
取而代之的是:
if (isPacked) {
return <li className="item">{name} ✔</li>;
}
return <li className="item">{name}</li>;
你可以这样写:
return (
<li className="item">
{isPacked ? name + ' ✔' : name}
</li>
);
你可以把它读作“如果 isPacked
是真的,那么 (?
)render name + ' ✔ '
,否则 (:
) render name
“。
function Item({ name, isPacked }) {
return (
<li className="item">
{isPacked ? (
<del>
{name + ' ✔'}
</del>
) : (
name
)}
</li>
);
}
export default function PackingList() {
return (
<section>
<h1>Sally Ride's Packing List</h1>
<ul>
<Item
isPacked={true}
name="Space suit"
/>
<Item
isPacked={true}
name="Helmet with a golden leaf"
/>
<Item
isPacked={false}
name="Photo of Tam"
/>
</ul>
</section>
);
}
这种风格适用于简单的条件,但要适度使用。如果组件因嵌套条件标记过多而变得混乱,请考虑提取子组件来清理。在 React 中,标记是代码的一部分,因此您可以使用变量和函数等工具来整理复杂的表达式。