迹忆客 专注技术分享

当前位置:主页 > 学无止境 > WEB前端 >

在 React 中检查变量是否为空

作者:迹忆客 最近更新:2022/09/19 浏览次数:

要在 React 中检查 null,请使用比较来检查值是否等于或不等于 null,例如 if (myValue === null) {}if (myValue !== null) {}。 如果满足条件,则 if 块将运行。

import {useEffect, useState} from 'react';

export default function App() {
  const [message, setMessage] = useState(null);

  useEffect(() => {
    // ✅ Check if NOT equal to null
    if (message !== null) {
      console.log('variable is NOT null');
    }

    // ✅ Check if null
    if (message === null) {
      console.log('variable is null');
    }

    // ✅ Check if value is NOT equal to null and undefined
    if (message !== undefined && message !== null) {
      console.log('variable is NOT undefined or null');
    }

    // ✅ Check if value is equal to null or undefined
    if (message === undefined || message === null) {
      console.log('variable is undefined or null');
    }
  }, [message]);

  return (
    <div>
      <button onClick={() => setMessage('Hello world')}>Set message</button>

      <h2>{message}</h2>
    </div>
  );
}

如果我们的第一个 if 语句,我们检查消息变量是否不等于 null

第二个示例检查变量是否等于 null

第三个 if 语句检查变量是否不等于 undefined 且不等于 null

第四个示例检查变量是否等于 undefined 或等于 null

我们使用 useEffect 钩子来跟踪消息状态变量的更改,但是我们可以在代码中的任何位置执行检查。

我们还可以检查变量是否存储真值。

真实值是所有不虚假的值。

JavaScript 中的假值是:undefinednullfalse0""(空字符串)、NaN(不是数字)。

import {useEffect, useState} from 'react';

export default function App() {
  const [message, setMessage] = useState(null);

  useEffect(() => {
    if (message) {
      console.log('✅ variable is truthy');
    }

    if (!message) {
      console.log('⛔️ variable is falsy');
    }
  }, [message]);

  return (
    <div>
      <button onClick={() => setMessage('Hello world')}>Set message</button>

      <h2>{message}</h2>
    </div>
  );
}

第一个条件检查消息变量是否存储真值。

该变量可以存储除了要满足的条件的 7 个虚假值之外的任何值。

第二个 if 语句检查变量是否存储 7 个虚假值之一 - undefinednullfalse0""(空字符串)、NaN(不是数字)。

本站文章均为原创或翻译,转载请发邮件至 1244347461@qq.com 进行申请,未经许可,禁止转载。经作者同意之后,转载请以链接形式注明出处

本文地址:

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

热门文章

教程更新

热门标签

扫码一下
查看教程更方便