
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 运算符用于检测数据类型:
大高朋团购系统是一套Groupon模式的开源团购程序,开发的一套网团购程序,系统采用ASP+ACCESS开发的团购程序,安装超简,功能超全面,在保留大高朋团购系统版权的前提下,允许所有用户免费使用。大高朋团购系统内置多种主流在线支付接口,所有网银用户均可无障碍支付;短信发送团购券和实物团购快递发货等。 二、为什么选择大高朋团购程序系统? 1.功能强大、细节完善 除了拥有主流团购网站功能,更特别支
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 代码。









