JSX 有条件地包括

简介: JSX 有条件地包括

如果有!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 中,标记是代码的一部分,因此您可以使用变量和函数等工具来整理复杂的表达式。

相关文章
|
JavaScript 前端开发
JS条件表达式
JS条件表达式
115 0
|
7月前
|
JavaScript 前端开发 索引
Vue嵌套循环渲染与条件渲染--v-for|v-if
Vue嵌套循环渲染与条件渲染--v-for|v-if
51 0
|
前端开发 JavaScript C++
Vue3-条件渲染
Vue3-条件渲染
52 0
|
7月前
|
JavaScript 前端开发 索引
Vue3基础之v-if条件与 v-for循环
Vue3基础之v-if条件与 v-for循环
204 0
|
7月前
|
JavaScript
Vue之条件渲染
Vue之条件渲染
|
7月前
|
JavaScript 前端开发
vue 条件渲染
vue 条件渲染
|
7月前
|
JavaScript
Vue 条件渲染 v-if
Vue 条件渲染 v-if
|
7月前
|
JavaScript
第28节: Vue3 条件渲染
第28节: Vue3 条件渲染
46 0
|
7月前
|
JavaScript 前端开发
js中new关键字的作用
js中new关键字的作用
57 0
|
JavaScript
03-Vue基础语法之指令语法与条件渲染
03-Vue基础语法之指令语法与条件渲染
63 0