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

相关文章
|
6月前
|
前端开发 JavaScript
React如何进行条件渲染
React如何进行条件渲染
42 0
|
6月前
|
JavaScript 前端开发 索引
Vue嵌套循环渲染与条件渲染--v-for|v-if
Vue嵌套循环渲染与条件渲染--v-for|v-if
43 0
|
JavaScript 前端开发
JS条件表达式
JS条件表达式
110 0
|
1月前
|
前端开发 JavaScript
React 条件渲染
10月更文挑战第9天
25 0
|
2月前
|
XML 前端开发 JavaScript
JSX 语法详解
【9月更文挑战第2天】本文详细介绍了React框架中核心组件JSX的基本概念与高级用法,包括基本语法、条件与列表渲染等。并通过具体示例讲解了如何避免常见的错误,如忘记闭合标签、未使用`key`属性及属性名大小写问题,帮助读者更好地理解和运用JSX,提升React应用程序的开发质量。
59 4
|
3月前
|
JavaScript
VUE——三元表达式动态渲染样式
VUE——三元表达式动态渲染样式
69 0
|
5月前
|
前端开发 JavaScript
REACT 条件渲染
REACT 条件渲染
|
6月前
|
JavaScript 前端开发 索引
Vue3基础之v-if条件与 v-for循环
Vue3基础之v-if条件与 v-for循环
183 0
|
JavaScript
JS三元表达式
JS三元表达式
65 0
|
6月前
|
前端开发
React 中条件渲染的 N 种方法
React 中条件渲染的 N 种方法
40 3