===要求值和类型都相同,不转换类型;==会强制类型转换后再比较,易产生反直觉结果,如0==false为true;开发中应优先使用===,仅在明确需宽松检查null/undefined时谨慎使用==。
JavaScript 中 == 和 === 都用于判断两个值是否相等,但核心区别在于:前者会自动进行类型转换(强制类型转换),后者要求值和类型都完全相同,不转换。
使用 == 时,如果左右两边类型不同,JavaScript 会按一套规则(抽象相等算法)把它们转成相同类型再比。这个过程容易产生反直觉结果:
0 == false → true(false 转为 0)"0" == false → true(false → 0,"0" → 0)null == undefined → true(这是特例,两者互相相等,但都不等于其他值)"1" == true → true(true → 1,"1" → 1)=== 要求左右两边的值和数据类型完全一致,只要有一个不同,就返回 false:
0 === false → false(number ≠ boolean)"0" === 0 → false(string ≠ number)null === undefined → false(类型不同)1 === 1 → true(同为 number,值也相同)日常开发中,强烈推荐优先使用 ===。它行为确定、可预测,避免隐式转换带来的 bug。只有极少数场景才考虑 ==:
立即学习“Java免费学习笔记(深入)”;
null 和 undefined 的宽松检查,比如 if (value == null) 等价于 value === null || value === undefined(但更推荐直接写后者)注意:无论是 == 还是 ===,对象(包括数组、函数)比较的都是引用地址,不是内容:
[1,2] == [1,2] → false
[1,2] === [1,2] → false
NaN == NaN → false(NaN 不等于任何值,包括自己;=== 同样如此)NaN 应该用 Number.isNaN() 或 isNaN()