接前文细分JavaScript的六种数据类型中的null和undefined

彻底搞懂 JavaScript 中的 nullundefined

在 JavaScript 开发中,nullundefined 是两个看似相似但含义截然不同的"空值"。它们经常被混淆,甚至在一些判断中导致意外的 bug。


一、核心定义:一句话说清区别

含义 谁赋予的
undefined "没有定义" ------ 变量声明了但没赋值,或属性不存在 JS 引擎自动赋予
null "有定义,但值为空" ------ 明确表示"这里本该有东西,但现在是空的" 程序员主动赋值

简单记忆

  • undefined = "我还没准备好"
  • null = "我知道你在找什么,但它现在是空的"

二、undefined 的常见场景与代码示例

1. 变量声明但未赋值

js 复制代码
let a;
console.log(a);           // undefined
console.log(typeof a);    // "undefined"

变量 a 被声明了,但没有给它任何值,JS 默认其值为 undefined


2. 函数没有返回值

js 复制代码
function doNothing() {
  // 没有 return
}

console.log(doNothing());        // undefined
console.log(typeof doNothing()); // "undefined"

如果函数没有 return 语句,调用结果就是 undefined


3. 对象属性不存在

js 复制代码
let person = {
  name: "张三"
};

console.log(person.age);         // undefined
console.log(typeof person.age);  // "undefined"

person 对象没有 age 属性,访问时返回 undefined


4. 数组元素不存在

js 复制代码
let arr = [1, 2, 3];
console.log(arr[5]);             // undefined
console.log(typeof arr[5]);      // "undefined"

数组索引 5 超出范围,返回 undefined


5. 函数参数未传

js 复制代码
function greet(name) {
  console.log("你好," + name);
}

greet(); // 你好,undefined

调用 greet() 时没有传参,name 参数默认为 undefined


三、null 的使用场景与代码示例

null 是一个程序员主动设置的空值,表示"我知道这里应该有一个值,但现在它是空的"。

1. 主动清空变量

js 复制代码
let user = { name: "李四", age: 25 };
user = null; // 表示当前没有用户

console.log(user);         // null
console.log(typeof user);  // "object" ❗️(这是 JS 的历史 bug)

user 设为 null,明确表示"当前无用户数据"。


2. 初始化可能为空的对象

js 复制代码
let selectedFile = null; // 先设为空,等待用户选择

// 后续逻辑中再赋值
// selectedFile = getFileFromInput();

提前告知其他开发者:"这个变量将来会是一个对象,但现在是空的"。


3. DOM 查询失败时返回 null

js 复制代码
let element = document.getElementById('non-existent');
console.log(element);         // null
console.log(typeof element);  // "object"

getElementById 找不到元素时返回 null,而不是 undefined,因为它"预期应该找到一个元素,但没找到"。


⚠️ 四、一个著名的"坑":typeof null === 'object'

js 复制代码
console.log(null, typeof null);     // null "object"
console.log(undefined, typeof undefined); // undefined "undefined"

typeof null 返回 "object",这是 JavaScript 最早期的一个历史 bug,至今未修复(为了兼容性)。

正确判断 null 的方式

js 复制代码
function isNull(value) {
  return value === null;
}

console.log(isNull(null));      // true
console.log(isNull(undefined)); // false

五、如何正确比较 nullundefined

1. 严格相等(===):推荐!

js 复制代码
console.log(null === undefined); // false  类型不同
console.log(null == undefined);  // true   宽松相等,会进行类型转换

永远使用 === 来避免类型隐式转换带来的问题。


2. 判断是否"为空值"(包括 null 和 undefined)

js 复制代码
function isEmpty(value) {
  return value == null; // 等价于 value === null || value === undefined
}

console.log(isEmpty(null));      // true
console.log(isEmpty(undefined)); // true
console.log(isEmpty(0));         // false
console.log(isEmpty(""));        // false

value == null 是判断"是否为 null 或 undefined"的高效写法。


六、最佳实践总结

场景 推荐做法
变量声明后暂时无值 undefined(JS 自动处理)
明确表示"无值" 主动赋值为 null
判断是否为空 使用 value == null
严格类型检查 使用 ===
清空对象引用 设为 null(帮助垃圾回收)

理解本质,写出更健壮的代码

  • undefined系统默认的"未定义"状态
  • null程序员主动设置的"空值"状态

掌握它们的区别,不仅能避免 bug,还能让你的代码更具语义化和可维护性。

下一次当你写 let user = null; 时,记住:你不是在"忽略"值,而是在明确表达意图

相关推荐
董世昌418 分钟前
箭头函数和普通函数有什么区别
开发语言·javascript·ecmascript
A242073493035 分钟前
js流程控制语句
开发语言·前端·javascript
yngsqq40 分钟前
二维异形排版、二维装箱(NPF碰撞检测)——CAD c#二次开发
开发语言·javascript·c#
AAA阿giao1 小时前
JavaScript 执行机制深度解析:从 V8 引擎到作用域链、变量提升与闭包的全面剖析
前端·javascript·面试
软件技术NINI1 小时前
html css js网页制作成品——陈都灵html+css 5页附源码
javascript·css·html
ohyeah1 小时前
用原生 JS 手写一个“就地编辑”组件:EditInPlace 的 OOP 实践
前端·javascript
毕设源码-邱学长1 小时前
【开题答辩全过程】以 基于JavaScript的图书销售网站为例,包含答辩的问题和答案
开发语言·javascript·ecmascript
重铸码农荣光1 小时前
深入理解 JavaScript 中的 this:一场关于作用域、调用方式与设计哲学的思辨
前端·javascript
珑墨2 小时前
【包管理器】pnpm、npm、cnpm、yarn 深度对比
前端·javascript·npm·node.js
草字2 小时前
uniapp 滚动到表单的某个位置,表单验证失败时。
前端·javascript·uni-app