严格相等 (===)

Baseline 已广泛支持

此特性已相当成熟,可在许多设备和浏览器版本上使用。自 ⁨2015 年 7 月⁩以来,各浏览器均已提供此特性。

严格相等 (===) 运算符检查其两个操作数是否相等,并返回一个布尔值结果。与相等运算符不同,严格相等运算符始终认为不同类型的操作数是不同的。

试一试

console.log(1 === 1);
// Expected output: true

console.log("hello" === "hello");
// Expected output: true

console.log("1" === 1);
// Expected output: false

console.log(0 === false);
// Expected output: false

语法

js
x === y

描述

严格相等运算符 (===!==) 提供了 IsStrictlyEqual 语义。

  • 如果操作数的类型不同,则返回 false
  • 如果两个操作数都是对象,则仅当它们引用同一个对象时才返回 true
  • 如果两个操作数都是 null 或两个操作数都是 undefined,则返回 true
  • 如果任一操作数为 NaN,则返回 false
  • 否则,比较两个操作数的值
    • 数字必须具有相同的数值。 +0-0 被认为是相同的值。
    • 字符串必须具有相同顺序的相同字符。
    • 布尔值必须都是 true 或都是 false

此运算符与相等 (==) 运算符之间最显著的区别是,如果操作数的类型不同,== 运算符会尝试在比较之前将它们转换为相同的类型。

示例

比较相同类型的操作数

js
"hello" === "hello"; // true
"hello" === "hola"; // false

3 === 3; // true
3 === 4; // false

true === true; // true
true === false; // false

null === null; // true

比较不同类型的操作数

js
"3" === 3; // false
true === 1; // false
null === undefined; // false
3 === new Number(3); // false

比较对象

js
const object1 = {
  key: "value",
};

const object2 = {
  key: "value",
};

console.log(object1 === object2); // false
console.log(object1 === object1); // true

规范

规范
ECMAScript® 2026 语言规范
# sec-equality-operators

浏览器兼容性

另见