javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > JavaScript判断变量null或undefined

JavaScript判断变量是否为null或undefined的方法及对比详解

作者:CAD老兵

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

一、undefined 与 null 的区别

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

二、各种判断方式

1. 使用宽松相等(==)

if (value == null) {
  // 相当于 value === null || value === undefined
}

优点:

注意:

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

if (value === null || value === undefined) {
  // 更明确的判断
}

优点:

缺点:

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

if (typeof value === 'undefined') {
  // 判断未定义
}

优点:

不判断 null,仅用于检测 undefined

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

let result = value ?? 'default';
// value 为 null 或 undefined 时使用 'default'

优点:

不适用于 0false'' 等“有效的 falsy 值”。

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

if (!(value != null)) {
  // 等价于 value == null
}

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

三、实际应用建议

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

四、陷阱与误用

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

if (!value) {
  // 会错误判断 0, "", false 为“空”
}

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

五、总结

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

六、附加建议

function isNil(val) {
  return val == null;
}

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

if (isNil(user)) {
  // user 为 null 或 undefined
}

结语

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

以上就是JavaScript判断变量是否为null或undefined的方法及对比详解的详细内容,更多关于JavaScript判断变量null或undefined的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文