判断变量是否为 `null` 或 `undefined` 的各种写法比较

在 JavaScript 中,判断一个变量是否为 nullundefined 是日常开发中非常常见的需求。虽然这两个值都表示"无值"或"空",但它们有本质区别,而判断的方式也有多种,适用于不同场景。本文将系统总结和比较这些写法,帮助你选择合适的方式编写更健壮的代码。


一、undefinednull 的区别

类型 含义 使用场景
undefined 变量声明了但未赋值 "未定义" 系统默认赋值
null 显式赋值为 null "空值" 表示有意的"无值"

二、各种判断方式

1. 使用宽松相等(==

js 复制代码
if (value == null) {
  // 相当于 value === null || value === undefined
}

✅ 优点:

  • 简洁、直观。
  • 同时判断 nullundefined

⚠️ 注意:

  • 宽松相等有时会被认为不严谨,容易被误用。
  • 不适用于 0false"" 这类也"falsy"的值。

2. 使用严格比较(===

js 复制代码
if (value === null || value === undefined) {
  // 更明确的判断
}

✅ 优点:

  • 精确控制判断条件。
  • 更显式、语义更清晰。

⚠️ 缺点:

  • == null 稍显冗长。

3. 使用 typeof(判断是否为 undefined

js 复制代码
if (typeof value === 'undefined') {
  // 判断未定义
}

✅ 优点:

  • 安全地判断未声明变量。
  • 可用于全局变量或未声明变量的判断。

**⚠️ 不判断 null,仅用于检测 undefined


4. 使用可选链与空值合并(ES2020+)

js 复制代码
let result = value ?? 'default';
// value 为 null 或 undefined 时使用 'default'

✅ 优点:

  • 适用于赋默认值。
  • 写法简洁,安全高效。

**⚠️ 不适用于 0false'' 等"有效的 falsy 值"。


5. 使用 == null 配合逻辑非(常见于布尔上下文)

js 复制代码
if (!(value != null)) {
  // 等价于 value == null
}

虽然不推荐,但在某些场景中可能看到这样的写法。建议保持代码可读性,优先使用清晰写法。


三、实际应用建议

场景 推荐写法
判断变量为 nullundefined if (value == null)
判断变量是否 不为 if (value != null)
安全读取属性 obj?.prop
给变量赋默认值 value ?? defaultValue
精确判断具体类型 if (value === null)typeof value === 'undefined'

四、陷阱与误用

⚠️ 使用 if (!value) 的局限性:

js 复制代码
if (!value) {
  // 会错误判断 0, "", false 为"空"
}

不推荐用于判断是否为 nullundefined,除非明确希望将 false0"" 也视为"无效值"。


五、总结

| 写法 | 判断 null | 判断 undefined | 简洁性 | 可读性 | 推荐度 |
|--------------------------------|---------|-----------------------|-------|-------|----------|-------|------|
| value == null | ✅ | ✅ | ★★★★☆ | ★★★★☆ | ⭐⭐⭐⭐ |
| `value === null | | value === undefined` | ✅ | ✅ | ★★★☆☆ | ★★★★★ | ⭐⭐⭐⭐ |
| typeof value === 'undefined' | ❌ | ✅ | ★★★☆☆ | ★★★☆☆ | ⭐⭐⭐ |
| value ?? defaultValue | ✅ | ✅ | ★★★★★ | ★★★★☆ | ⭐⭐⭐⭐ |
| if (!value) | ✅ | ✅ | ★★★★★ | ★★☆☆☆ | ⭐⭐(谨慎使用) |


六、附加建议

  • 对公共函数或 API 入参,建议使用显式判断,避免类型模糊带来的副作用。
  • 编写工具函数提高可读性,例如:
js 复制代码
function isNil(val) {
  return val == null;
}

这样在阅读代码时更具语义性:

js 复制代码
if (isNil(user)) {
  // user 为 null 或 undefined
}

结语

判断变量是否为 nullundefined 是基础但关键的技巧。理解每种写法的语义与适用场景,能写出更健壮、更易维护的代码。在日常开发中,推荐统一使用 value == nullvalue ?? 等更现代、更语义化的写法,提升代码一致性和可读性。

相关推荐
顾安r3 小时前
11.8 脚本网页 星际逃生
c语言·前端·javascript·flask
Hello.Reader3 小时前
Data Sink定义、参数与可落地示例
java·前端·网络
im_AMBER3 小时前
React 17
前端·javascript·笔记·学习·react.js·前端框架
谷歌开发者4 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (六)
前端·chrome·学习
一晌小贪欢4 小时前
【Html模板】电商运营可视化大屏模板 Excel存储 + 一键导出(已上线-可预览)
前端·数据分析·html·excel·数据看板·电商大屏·大屏看板
发现你走远了4 小时前
连接模拟器网页进行h5的调试(使用Chrome远程调试(推荐)) 保姆级图文
前端·chrome
街尾杂货店&5 小时前
css - 实现三角形 div 容器,用css画一个三角形(提供示例源码)简单粗暴几行代码搞定!
前端·css
顺凡6 小时前
删一个却少俩:Antd Tag 多节点同时消失的原因
前端·javascript·面试
小白路过6 小时前
CSS transform矩阵变换全面解析
前端·css·矩阵
爬山算法6 小时前
Redis(110)Redis的发布订阅机制如何使用?
前端·redis·bootstrap