react 逻辑 AND 运算符 (&&)

在 React 组件中,当你想在条件为 true 时渲染一些 JSX 时,它经常会出现**,或者什么都不渲染。** 使用 ,只有在以下情况下才能有条件地呈现复选标记:&&``isPacked``true

javascript 复制代码
return (
  <li className="item">
    {name} {isPacked && '✔'}
  </li>
);

您可以将其理解为*"if isPacked, then (&&) render the checkmark, else , render nothing "*。

这是在行动:

javascript 复制代码
function Item({ name, isPacked }) {
  return (
    <li className="item">
      {name} {isPacked && '✔'}
    </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>
  );
}

如果 JavaScript 的左侧(我们的条件)为 ,则 JavaScript && 表达式返回其右侧的值(在本例中为复选标记)。但是如果条件是 ,则整个表达式变为 。React 将其视为 JSX 树中的一个"洞",就像 或 一样,并且不会在其位置上渲染任何东西。true``false``false``false``null``undefined

不要将数字放在 &&. 的左侧。

为了测试条件,JavaScript 会自动将左侧转换为布尔值。但是,如果左侧是 ,那么整个表达式都会得到该值 (),并且 React 会很乐意渲染而不是什么都没有。0``0``0

例如,一个常见的错误是编写类似 .很容易假设它在 is 时什么都不渲染,但它确实渲染了它本身!messageCount && <p>New messages</p>``messageCount``0``0

要修复它,请将左侧设为布尔值:。messageCount > 0 && <p>New messages</p>

有条件地将 JSX 分配给变量

当快捷方式妨碍编写纯代码时,请尝试使用语句和变量。您可以重新分配使用 let 定义的变量,因此首先提供要显示的默认内容,即名称:if

javascript 复制代码

let itemContent = name;

使用语句将 JSX 表达式重新赋值给 if :if``itemContent``isPacked``true

javascript 复制代码

if (isPacked) {
itemContent = name + " ✔";
}

大括号打开"JavaScript 之窗"。在返回的 JSX 树中嵌入带有大括号的变量,将先前计算的表达式嵌套在 JSX 中:

javascript 复制代码

<li className="item">
{``itemContent}
</li>

这种风格是最冗长的,但也是最灵活的。这是在行动:

javascript 复制代码
function Item({ name, isPacked }) {
  let itemContent = name;
  if (isPacked) {
    itemContent = name + " ✔";
  }
  return (
    <li className="item">
      {itemContent}
    </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>
  );
}
相关推荐
云梦谭3 分钟前
AI 生成的FreeSWITCH 呼出流程深度分析freeswitch-1.10.12.-release
java·前端·php
一只爱吃糖的小羊6 分钟前
React 19:革命性升级与全面使用指南
react.js
秃了才能变得更强7 分钟前
React Native小技巧
前端
一只爱吃糖的小羊7 分钟前
React 19 vs Vue 3:深度对比与选型指南
前端·vue.js·react.js
我也想好好学习8 分钟前
使用Promise实现串行执行异步任务,含出错重试功能
javascript
前端老宋Running8 分钟前
Vue 3 的“降维打击”:Composition API 是如何让 Mixin 成为历史文物的?
前端·javascript·vue.js
Pluto_CRown9 分钟前
H5 开发的各类小知识点
前端·javascript
Pluto_CRown9 分钟前
上下文存储【下】
前端·javascript
AAA阿giao10 分钟前
JavaScript 中基于原型和原型链的继承方式详解
前端·javascript·面试
用户6000718191011 分钟前
【翻译】如何在Vue中使用Suspense处理异步渲染?
前端