当前位置: 首页 > news >正文

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 容器选型案例,一篇看懂》

http://www.jsqmd.com/news/81573/

相关文章:

  • 图书管理|基于Java+ vue图书管理系统(源码+数据库+文档)
  • Vim-tmux-navigator终极指南:彻底改变你的开发工作流
  • 2025年知名的医药标签实力厂家TOP推荐榜 - 品牌宣传支持者
  • 2025年知名的红酒木盒/收藏木盒品牌厂家排行榜 - 行业平台推荐
  • 【YOLO11-MM 多模态目标检测】空间依赖感知模块(SpatialDependencyPerception)增强小目标边缘细节纹理
  • 2025年靠谱的闪蒸干燥机厂家最新TOP排行榜 - 行业平台推荐
  • 2025年热门的巧克力包装机厂家最新权威实力榜 - 行业平台推荐
  • At.js测试实战指南:5个步骤掌握高质量自动化测试
  • 在线教育学习|基于java + vue在线教育学习系统(源码+数据库+文档)
  • 实用指南:【LeetCode】89. 格雷编码
  • 【YOLO11-MM 多模态目标检测】序列混洗注意力模块(SSA)、保持输入图像的局部性和连续性
  • 解锁115云盘下载新姿势:这款神器让你批量下载效率翻倍![特殊字符]
  • 代码检索效率革命:OASIS-1.3B如何用5M数据超越OpenAI同类模型
  • 2025年靠谱的黑金沙花岗岩厂家推荐及采购指南 - 行业平台推荐
  • 约束编程在除雪车路线优化中的应用与实现
  • 出行旅游安排|基于Java + vue出行旅游安排系统(源码+数据库+文档)
  • 学生管理|基于Java + vue学生管理系统(源码+数据库+文档)
  • 2025年12月最新粒度仪行业品牌排行榜,干法/湿法激光粒度仪/在线粒度分析仪专业源头生产厂家/供应商/制造商推荐 - 品牌推荐大师1
  • MailKit深度解析:5个提升Gmail集成性能的高级技巧
  • 专业塑料方便袋供应企业大揭秘:选对厂家很重要 - myqiye
  • 240亿参数重塑企业AI格局:Magistral Small 1.1如何助力中小企业落地
  • 2025年质量好的樱花红花岗岩厂家最新推荐排行榜 - 品牌宣传支持者
  • Qbot智能量化交易平台完整安装指南:从零开始部署你的AI投资助手
  • P9528 [JOIST 2022] 蚂蚁与方糖 / Ants and Sugar
  • 环保与实用兼具:塑料方便袋生产厂的靠谱之选 - 工业推荐榜
  • https://codeforces.com/problemset/problem/1487/C
  • 从零到千亿:用Megatron-LM解锁大语言模型训练的终极密码
  • Ink/Stitch:重新定义刺绣设计的开源革命
  • 2025年评价高的防松抗振紧固件/不锈钢紧固件厂家推荐及选择参考 - 行业平台推荐
  • 7个Vim插件开发技巧:从入门到精通的完整指南