JS 中判断 null、undefined 与 NaN 的权威方法及场景实践

在 JavaScript 中,nullundefined 和 NaN 是三个特殊的「非正常值」,正确判断它们是保证代码健壮性的关键。本文结合 ECMA 规范与 MDN 权威文档,系统梳理三者的判断方法、原理及典型场景,帮助开发者规避常见误区。

一、理解三个特殊值的本质

  • undefined:表示「变量未初始化」或「对象属性未显式赋值」(如声明变量未赋值、访问不存在的对象属性)。
  • null:表示「有意为之的空值」(通常用于表示「空对象」,如 let obj = null)。
  • NaN(Not a Number):表示「非数字」,常见于数值计算失败场景(如 0/0"abc" - 1)。

二、判断 undefined 的权威方法

undefined 的核心特征是「未初始化」,判断时需注意兼容性。

1. 使用 typeof(推荐,兼容未声明变量)

typeof 返回变量的类型字符串("undefined" 表示未初始化)。即使变量未声明,typeof 也不会抛出错误,适合安全检查。

javascript

// 变量已声明但未初始化
let a; 
console.log(typeof a === "undefined"); // true// 检查对象不存在的属性(安全)
const obj = { name: "张三" };
console.log(typeof obj.age === "undefined"); // true(age属性未定义)// 变量未声明(不会报错)
console.log(typeof b === "undefined"); // true(b未声明)
2. 直接比较 === undefined(需变量已声明)

若变量已声明,可通过严格等于 undefined 判断,但未声明变量会抛出 ReferenceError

javascript

let c; 
console.log(c === undefined); // true(变量已声明未初始化)// 未声明变量直接比较会报错!
// console.log(d === undefined); // Uncaught ReferenceError: d is not defined

三、判断 null 的权威方法

null 是「主动设置的空对象」,需严格区分于其他值。

唯一可靠方式:=== null

typeof null 会返回 "object"(历史遗留问题),因此必须通过严格等于 null 判断。

javascript

const obj = null;
console.log(obj === null); // true(正确判断null)// 错误示例:typeof无法区分null和对象
console.log(typeof null); // "object"(无法用typeof判断null)

四、判断 NaN 的权威方法

NaN 是唯一不满足 x === x 的值(NaN !== NaN),判断需结合其特性。

1. ES6 新增 Number.isNaN(严格判断,推荐)

仅当值本身是 NaN 时返回 true,不会隐式转换其他类型。

javascript

console.log(Number.isNaN(NaN)); // true(直接判断NaN)
console.log(Number.isNaN("abc" - 1)); // true(计算结果为NaN)
console.log(Number.isNaN("123")); // false(字符串不是NaN)
2. 传统 isNaN(非严格,需谨慎)

先将参数隐式转换为数字,再判断是否为 NaN,可能误判其他类型。

javascript

console.log(isNaN(NaN)); // true(正确)
console.log(isNaN("abc")); // true("abc"转数字为NaN)
console.log(isNaN("123")); // false("123"转数字为123)
3. 利用 NaN !== NaN 特性(兼容旧环境)

NaN 是唯一不满足自身相等的值,可手动实现判断函数。

javascript

function isNaNPolyfill(value) {return value !== value; 
}
console.log(isNaNPolyfill(NaN)); // true
console.log(isNaNPolyfill("abc" - 1)); // true(结果为NaN)

五、综合场景与补充方法

实际开发中,需根据需求灵活组合判断逻辑。

场景 1:统一判断 null 或 undefined

利用宽松相等(null == undefined 为 true),快速判断两者。

javascript

const value = null;
if (value == null) { // 等价于 value == undefinedconsole.log("值为null或undefined"); // 触发
}
场景 2:函数参数默认值处理(ES6 解构赋值)

解构赋值的默认值仅在参数为 null 或 undefined 时生效,其他假值(如 0)不触发。

javascript

function getUserInfo({ age = "未知" } = {}) { console.log(`年龄:${age}`);
}getUserInfo({ age: null }); // 输出 "年龄:未知"(null触发默认值)
getUserInfo({ age: 0 }); // 输出 "年龄:0"(0是有效值,不触发默认值)
场景 3:使用工具库(如 Lodash)

成熟工具库提供语义化方法,提升代码可读性。

javascript

import { isNil, isNull, isUndefined } from "lodash";isNull(null); // true(仅判断null)
isUndefined(undefined); // true(仅判断undefined)
isNil(null); // true(判断null或undefined)
isNil(undefined); // true

六、总结与最佳实践

权威判断方法适用场景
undefinedtypeof value === "undefined"安全检查未声明变量或对象属性
nullvalue === null明确判断「主动设置的空对象」
NaNNumber.isNaN(value)(ES6)严格判断非数字结果
综合判断value == null(null/undefined)
lodash.isNil(工具库)
无需区分 null 和 undefined 时快速过滤

参考规范

  • ECMA-262 规范:typeof、Null、NaN。
  • MDN 文档:undefined、null、NaN。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/84257.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于DenseNet的医学影像辅助诊断系统开发教程

本文源码地址: https://download.csdn.net/download/shangjg03/90873921 1. 简介 本教程将使用DenseNet开发一个完整的医学影像辅助诊断系统,专注于胸部X光片的肺炎检测。我们将从环境搭建开始,逐步介绍数据处理、模型构建、训练、评估以及最终的系统部署。 2. 环境准备<…

ubuntu ollama /Dify/Docker部署大模型

电脑需要显卡&#xff1a; 执行下载并安装&#xff1a; curl -fsSL https://ollama.com/install.sh | sh 安装完后到Ollama Search 中查看ollama 可以部署的模型有哪些&#xff1a; 我选择gemma3,所以执行&#xff1a; ollma pull gemma3:latest 这样就把gemma3:latest 模…

课程发布与学习流程全解析

流程 课程发布Controller 获取课程发布信息 ApiOperation("获取课程发布信息") ResponseBody GetMapping("/course/whole/{courseId}") public CoursePreviewDto getPreviewInfo(PathVariable("courseId") Long courseId) {CoursePreviewDto c…

Linux的读写屏障

在 Linux 中&#xff0c;读写屏障&#xff08;Read-Write Barriers&#xff0c;简称 RWB&#xff09;是对内存访问顺序的一种控制机制&#xff0c;用来保证在多核处理器环境下&#xff0c;内存访问的正确顺序&#xff0c;避免因乱序执行导致的数据一致性问题。它是操作系统内核…

Spring AI 和 Elasticsearch 作为你的向量数据库

作者&#xff1a;来自 Elastic Josh Long, Philipp Krenn 及 Laura Trotta 使用 Spring AI 和 Elasticsearch 构建一个完整的 AI 应用程序。 Elasticsearch 原生集成了业界领先的生成式 AI 工具和服务提供商。查看我们关于超越 RAG 基础或使用 Elastic 向量数据库构建生产级应用…

TDengine 高可用——双活方案

概述 部分用户因为部署环境的特殊性只能部署两台服务器&#xff0c;同时希望实现一定的服务高可用和数据高可靠。本文主要描述基于数据复制和客户端 Failover 两项关键技术的 TDengine 双活系统的产品行为&#xff0c;包括双活系统的架构、配置、运维等。TDengine 双活既可以用…

与 JetBrains 官方沟通记录(PyCharm 相关问题反馈)

#工作记录 沟通记录&#xff1a; Subject: Feedback on Terminal and Environment Activation Issues in PyCharm : PY-81233 沟通进度&#xff1a; 【笔记】记一次PyCharm的问题反馈_the polyglot context is using an implementation th-CSDN博客 【笔记】与PyCharm官方沟通…

前端实战:用 JavaScript 模拟文件选择器,同步实现图片预览与 Base64 转换

代码 function 仙盟插件_通用_图片_上传(人间通道id,检验关卡img,仙界指引id){const 人间通道 document.getElementById(人间通道id);const 检验关卡 document.getElementById(检验关卡img);const 仙界指引 document.getElementById(仙界指引id);人间通道.addEventListener(…

数据库设计文档撰写攻略

数据库设计文档撰写攻略 一、数据库设计文档的核心价值二、数据库设计文档的核心框架与内容详解2.1 文档基础信息2.2 需求分析与设计原则2.2.1 业务需求概述2.2.2 设计原则 2.3 数据模型设计2.3.1 概念模型&#xff08;ER 图&#xff09;2.3.2 逻辑模型&#xff08;表结构设计&…

3D个人简历网站 7.联系我

3D个人简历网站 7.联系我 修改Contact.jsx // 从 react 库导入 useRef 和 useState hooks import { useRef, useState } from "react";/*** Contact 组件&#xff0c;用于展示联系表单&#xff0c;处理用户表单输入和提交。* returns {JSX.Element} 包含联系表单的 …

AI大模型从0到1记录学习numpy pandas day25

第 3 章 Pandas 3.1 什么是Pandas Pandas 是一个开源的数据分析和数据处理库&#xff0c;它是基于 Python 编程语言的。 Pandas 提供了易于使用的数据结构和数据分析工具&#xff0c;特别适用于处理结构化数据&#xff0c;如表格型数据&#xff08;类似于Excel表格&#xff09;…

一些可以优化JavaScript性能的工具或库汇总

在 JavaScript 性能优化方面,有许多实用的工具和库可以帮助你分析、监控和提升代码性能。以下是一些常用的工具和库分类整理: 一、性能分析工具 这些工具用于诊断性能瓶颈,定位问题代码。 Chrome DevTools Performance 面板:分析运行时性能,记录函数执行时间、内存使用、…

Linux | tmux | 无法复制粘贴

问题&#xff1a;在Linux中使用tmux时&#xff0c;总是没法使用复制粘贴功能&#xff1b; 解决: 如果希望直接用鼠标选择并复制&#xff08;类似普通终端&#xff09;&#xff0c;可以&#xff1a; 在 ~/.tmux.conf 中添加&#xff1a;sh set -g mouse on;重新加载 tmux 配置…

行贿罪案件(公安侦查阶段)询问笔录发问提纲

一、基本情况核实 与行贿对象&#xff08;受贿人&#xff09;的关系&#xff1f;何时通过何种方式认识&#xff1f;日常交往频率及主要内容&#xff1f; 是否具备国家工作人员身份或其他特定主体资格&#xff1f;是否属于被追诉单位的直接责任人员&#xff1f; 二、行贿动机与…

活到老学到老-Spring参数校验注解Validated /Valid

通过 Validated 和 Valid可以对请求的进行参数校验。 1.核心对比&#xff1a; 特性Valid (JSR-303)Validated (Spring)来源Java标准规范Spring框架扩展分组校验不支持支持&#xff08;通过groups属性&#xff09;嵌套路径自动处理级联校验需配合Valid生效应用范围方法参数、属…

【笔记】JetBrains 数据迁移与符号链接操作

数据迁移与符号链接操作 一、备份原始数据 使用 robocopy 命令备份 C 盘中的源文件夹&#xff0c;确保原始数据完整备份。 robocopy "C:\Users\love\AppData\Local\JetBrains" "E:\Downloads\Other\JetBrains" /E确保备份路径足够存储空间。 二、复制文…

使用 Terraform 创建 Azure Databricks 工作区

使用 Terraform 创建 Azure Databricks Terraform 是一种基础设施即代码(IaC)工具,允许用户通过声明式配置文件来管理和部署云资源。Azure Databricks 是一个基于 Apache Spark 的分析平台,专为数据工程和数据科学设计。通过 Terraform,可以自动化 Azure Databricks 的创…

【zookeeper】--部署3.6.3

文章目录 下载解压创建data和logs配置文件1)创建目录并且编辑 zoo.cfg2)接下来将 node01 的 ZooKeeper 所有文件拷贝至 node02 和 node03。推荐从 node02 和 node03 拷贝4&#xff09;最后 vim /etc/profile 配置环境变量&#xff0c;环境搭建结束。配完环境变量后 source /etc…

RxJS 核心操作符详细用法示例

1. Observable 详细用法 Observable 是 RxJS 的核心概念&#xff0c;代表一个可观察的数据流。 创建和订阅 Observable import { Observable } from "rxjs";// 1. 创建Observable const myObservable new Observable(subscriber > {// 发出三个值subscriber.n…

QGrphicsScen画布网格和QGrphicsItem对齐到网格

#include <QGraphicsScene> #include <QPainter> #include <QWheelEvent> #include <QGraphicsView> class MyGraphicsView : public QGraphicsView { public:MyGraphicsView(QGraphicsScene* scene) : QGraphicsView(scene){}protected:// 重写滚轮事…