news 2026/4/3 2:43:09

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/4/1 4:34:40

Wan2.2 Fun-VACE终极指南:三合一视频生成神器快速上手

Wan2.2 Fun-VACE作为阿里巴巴PAI团队推出的新一代视频生成模型,首次将首尾帧控制、动态参考驱动与角色智能替换三大核心功能完美融合。这款革命性的AI创作工具不仅继承了前代版本的技术优势,更通过创新的混合专家架构和量化技术,实现了视频生…

作者头像 李华
网站建设 2026/3/31 23:29:33

30秒电影级视频生成:WAN2.2-14B极速工作流重构创作范式

导语 【免费下载链接】WAN2.2-14B-Rapid-AllInOne 项目地址: https://ai.gitcode.com/hf_mirrors/Phr00t/WAN2.2-14B-Rapid-AllInOne 阿里通义万相团队开源的WAN2.2-14B-Rapid-AllInOne模型,以140亿参数实现"四合一"全能视频生成,8GB显…

作者头像 李华
网站建设 2026/3/31 22:37:25

Apache Fineract:重塑普惠金融的开放银行平台解决方案

Apache Fineract 是一款功能强大的开源微金融服务平台,为全球30亿缺乏传统银行服务的人群提供数字化金融解决方案。这个由Apache软件基金会支持的开放银行平台,通过现代化的技术架构和丰富的API接口,帮助金融机构快速搭建核心银行系统&#x…

作者头像 李华
网站建设 2026/3/31 22:29:45

UL94-2018中文版防火试验标准完整指南

UL94-2018中文版防火试验标准文件为研究人员和工程师提供了完整的垂直燃烧测试规范。这份权威标准详细规定了V-0、V-2等级的测试流程和样品要求,是防火材料测试的重要参考依据。 【免费下载链接】UL94-2018中文版资源文件下载说明 《UL94-2018中文版》是一份关于UL9…

作者头像 李华
网站建设 2026/3/21 0:22:25

3步搞定PlayCanvas中继功能:零延迟多人协作终极指南

3步搞定PlayCanvas中继功能:零延迟多人协作终极指南 【免费下载链接】editor Issue tracker for the PlayCanvas Editor 项目地址: https://gitcode.com/GitHub_Trending/editor11/editor 想要在PlayCanvas Editor中实现无缝的多人实时协作吗?中继…

作者头像 李华
网站建设 2026/3/31 23:06:28

TorrServer 终极使用指南:如何快速搭建个人流媒体服务器

TorrServer 终极使用指南:如何快速搭建个人流媒体服务器 【免费下载链接】TorrServer Torrent stream server 项目地址: https://gitcode.com/gh_mirrors/to/TorrServer TorrServer 是一款功能强大的开源流媒体服务器,能够在线播放种子文件内容而…

作者头像 李华