JavaScript 的严格相等运算符 (===) 乍看简单,却暗藏玄机。本文将解释为何 1 === 1 为真,而 {} === {} 为假。
数据类型:基元与对象
理解这一差异的关键在于 JavaScript 如何处理基元类型和对象类型。
基元类型: 包括数字、字符串、布尔值、undefined、null 和 Symbol。使用 === 比较基元时,JavaScript 直接比较其值。1 === 1 为真,因为它们的值相同。
对象类型: 对象存储在堆内存中。每次创建对象,都会分配新的内存地址。=== 比较对象时,比较的是其内存地址,而非内容。{} 和 {} 是两个不同的对象,位于不同的内存地址,因此 {} === {} 为假。
内存与堆:更深入的理解
下图简要说明:
const obj1 = {}; // 内存地址 a const obj2 = {}; // 内存地址 b console.log(obj1 === obj2); // false, a !== b const obj3 = obj1; // obj3 指向与 obj1 相同的内存地址 console.log(obj1 === obj3); // true, 都指向 a
对象是引用类型,比较的是引用(内存地址),而非值。
typeof 运算符
typeof 运算符用于检测数据类型:
console.log(typeof "hello"); // "string" console.log(typeof 42); // "number" console.log(typeof true); // "boolean" console.log(typeof undefined);// "undefined" console.log(typeof null); // "object" (已知 bug) console.log(typeof {}); // "object" console.log(typeof []); // "object" console.log(typeof function () {}); // "function"
null 和数组:对象的特殊情况
typeof null 返回 "object" 是 JavaScript 的一个历史遗留问题。数组和函数实际上是对象。
函数:特殊的对象
函数是对象,但拥有 [[call]] 属性,使其可调用。
function greet() { console.log("hello!"); } greet(); // "hello!"
重要性
理解基元和对象的区别至关重要。比较对象内容,需使用深度比较,例如:
const objA = { name: "Alice" }; const objB = { name: "Alice" }; // 浅比较 console.log(objA === objB); // false // 深比较 const isEqual = JSON.stringify(objA) === JSON.stringify(objB); console.log(isEqual); // true
结论
1 === 1 为真,因为基元按值比较;{} === {} 为假,因为对象按引用比较。掌握这一区别,有助于编写更健壮的 JavaScript 代码。
以上就是为什么 == 为 true 但 {} === {} 为 false的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号