news 2026/6/23 12:00:21

JavaScript 中如何正确判断 null 和 undefined?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JavaScript 中如何正确判断 null 和 undefined?

相信写前端开发的朋友对下面这种报错应该很熟悉:

Cannot read properties of undefined

有一次我加班处理问题,也是因为这一个bug。

后来才发现,原来是一个接口返回的数据里,某个字段有时候是null导致的,而我没有做判断就直接使用了。

一、为什么需要判断空值?

举例如下:

// 场景1:用户没填姓名constuserName=undefined;console.log(userName.length);// 报错!Cannot read properties of undefined// 场景2:接口返回空数据constapiResponse=null;console.log(apiResponse.data);// 报错!Cannot read properties of null

所以,空值判断是保证代码健壮性的重要环节。


二、先搞懂:null 和 undefined 有啥区别?

虽然它们都表示空,但含义不同:

undefined:变量被声明了,但还没赋值。

letname;console.log(name);// undefined

null:程序员主动赋值为空,表示我明确知道这里没有值。

letuser=null;// 表示“用户不存在”

所以,当我们说判断变量是否为空,通常是指:它是不是nullundefined


判断方法

以下介绍了比较常用的几种判断方案。

方法一:显式比较(最保险)

if(variable===null||variable===undefined){console.log('变量为空');}

适用场景

  • 需要明确区分null和undefined时
  • 团队代码规范要求严格相等判断
  • 对代码可读性要求高的项目

案例

functiongetUserProfile(user){if(user===null||user===undefined){return'用户不存在';}return`欢迎,${user.name}`;}

方法二:非严格相等(最常用)

if(variable==null){console.log('变量为空');}

这里有个重要知识点== null实际上等价于=== null || === undefined,这是JavaScript的语言特性。

为什么推荐这个写法?

  • 代码简洁,少写很多字符
  • 性能优秀,现代JS引擎都做了优化
  • 意图明确,专业开发者一看就懂

方法三:逻辑非操作符

if(!variable){console.log('变量为falsy值');}

注意!这个方法容易造成其它的误伤:

// 这些值都会被判断为"空"!false// true!0// true!""// true!NaN// true// 实际开发中的坑constcount=0;if(!count){console.log('计数为0');// 这里会执行,但可能不是我们想要的}

方法四:typeof 关键字(安全的写法)

if(typeofvariable==='undefined'||variable===null){console.log('变量是空的!');}

安全在哪?

// 如果变量根本没声明,前两种方法会报错if(notDeclaredVariable==null){// 报错!ReferenceError}if(typeofnotDeclaredVariable==='undefined'){// 正常运行!console.log('变量未定义');}

这种写法主要用于检查一个变量是否被声明过,但对于普通函数参数或已声明变量,没必要这么复杂。

适用于不确定变量是否声明的场景。


方法五:空值合并操作符(现代写法)

这是ES2020的新特性,用起来特别顺手:

// 传统写法constname=username?username:'匿名用户';// 现代写法constname=username??'匿名用户';

优势:只对nullundefined生效,不会误判0、false等其他值。


方法六:可选链操作符(对象属性专用)

处理嵌套对象时,这个功能简直是救命稻草:

// 以前的痛苦写法conststreet=user&&user.address&&user.address.street;// 现在的优雅写法conststreet=user?.address?.street;

结合空值合并,写法更加安全:

conststreet=user?.address?.street??'地址未知';

实际开发中的建议

场景1:简单的空值检查

// 推荐if(value==null){// 处理空值}// 或者constsafeValue=value??defaultValue;

场景2:需要区分null和undefined

if(value===null){console.log('明确设置为空');}if(value===undefined){console.log('未定义');}

场景3:处理对象属性

// 安全访问深层属性constphone=order?.customer?.contact?.phone??'未填写';

场景4:函数参数默认值

functioncreateUser(name,age=18){// age参数只在undefined时使用默认值return{name,age};}

总结

虽然现代JavaScript引擎优化得很好,但了解原理还是有帮助的:

  1. == null和显式比较性能相当
  2. typeof检查稍慢,但能安全检测未声明变量
  3. 可选链操作符在现代浏览器中性能优秀
场景推荐写法原因
一般空值检查value == null简洁高效
需要明确意图value === null
设置默认值value ?? defaultValue安全准确
对象属性访问obj?.prop避免报错
函数参数参数默认值语言特性

没有绝对最好的方法,只有最适合当前场景的选择。根据你的具体需求和团队规范来决策吧!

本文首发于公众号:程序员刘大华,专注分享前后端开发的实战笔记。关注我,少走弯路,一起进步!

📌往期精彩

《async/await 到底要不要加 try-catch?异步错误处理最佳实践》

《如何查看 SpringBoot 当前线程数?3 种方法亲测有效》

《Java 开发必看:什么时候用 for,什么时候用 Stream?》

《别再乱 new ArrayList!8 大 Java 容器选型案例,一篇看懂》

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 16:42:53

320亿参数大模型单GPU部署:IBM Granite-4.0量化版改写企业AI规则

320亿参数大模型单GPU部署:IBM Granite-4.0量化版改写企业AI规则 【免费下载链接】granite-4.0-h-small-unsloth-bnb-4bit 项目地址: https://ai.gitcode.com/hf_mirrors/unsloth/granite-4.0-h-small-unsloth-bnb-4bit 导语 IBM与Unsloth联合推出的Granit…

作者头像 李华
网站建设 2026/6/23 16:38:58

沉浸式翻译扩展无法启动的7个修复技巧

沉浸式翻译扩展无法启动的7个修复技巧 【免费下载链接】immersive-translate 沉浸式双语网页翻译扩展 , 支持输入框翻译, 鼠标悬停翻译, PDF, Epub, 字幕文件, TXT 文件翻译 - Immersive Dual Web Page Translation Extension 项目地址: https://gitc…

作者头像 李华
网站建设 2026/6/23 2:29:49

Czkawka深度实战手册:macOS存储空间优化终极指南

在macOS系统中,存储空间管理始终是用户面临的核心挑战。当Finder的重复文件搜索变得低效,当系统清理工具无法满足深度需求时,Czkawka作为一款基于Rust构建的跨平台清理工具,以其毫秒级扫描速度和多维度清理能力,成为ma…

作者头像 李华
网站建设 2026/6/22 23:34:21

BiliFM:三分钟学会B站音频批量下载终极指南

BiliFM:三分钟学会B站音频批量下载终极指南 【免费下载链接】BiliFM 下载指定 B 站 UP 主全部或指定范围的音频,支持多种合集。A script to download all audios of the Bilibili uploader you love. 项目地址: https://gitcode.com/jingfelix/BiliFM …

作者头像 李华
网站建设 2026/6/23 16:39:55

如何快速搭建intl-tel-input开发环境:从Grunt到Jest的完整指南

如何快速搭建intl-tel-input开发环境:从Grunt到Jest的完整指南 【免费下载链接】intl-tel-input A JavaScript plugin for entering and validating international telephone numbers 项目地址: https://gitcode.com/gh_mirrors/in/intl-tel-input intl-tel-…

作者头像 李华
网站建设 2026/6/22 20:42:48

HCIA-Cloud Computing 云计算认证终极指南:7大核心模块完整教程

想要快速掌握华为云计算认证的核心知识?这份精心打造的HCIA-Cloud Computing学习资源是你的最佳选择!无论你是零基础小白还是希望深化理解的IT专业人士,都能通过这套完整教程在30天内建立系统的云计算知识体系,为华为云计算认证考…

作者头像 李华