JavaScript中如何比较相等_==和===有什么不同

13次阅读

===要求值和类型都相同,不转换类型;==会强制类型转换后再比较,易产生反直觉结果,如0==false为true;开发中应优先使用===,仅在明确需宽松检查NULL/undefined时谨慎使用==。

JavaScript中如何比较相等_==和===有什么不同

javaScript 中 ===== 都用于判断两个值是否相等,但核心区别在于:前者会自动进行类型转换(强制类型转换),后者要求值和类型都完全相同,不转换。

== 是“抽象相等”,会尝试转换类型再比较

使用 == 时,如果左右两边类型不同,javascript 会按一套规则(抽象相等算法)把它们转成相同类型再比。这个过程容易产生反直觉结果:

  • 0 == falsetruefalse 转为 0
  • "0" == falsetruefalse0"0"0
  • null == undefinedtrue(这是特例,两者互相相等,但都不等于其他值)
  • "1" == truetruetrue1"1"1

=== 是“严格相等”,不转换类型,直接比较

=== 要求左右两边的值和数据类型完全一致,只要有一个不同,就返回 false

  • 0 === falsefalsenumberBoolean
  • "0" === 0falseStringnumber
  • null === undefinedfalse(类型不同)
  • 1 === 1true(同为 number,值也相同)

什么时候该用哪一个?

日常开发中,强烈推荐优先使用 ===。它行为确定、可预测,避免隐式转换带来的 bug。只有极少数场景才考虑 ==

立即学习Java免费学习笔记(深入)”;

  • 明确需要兼容 nullundefined 的宽松检查,比如 if (value == null) 等价于 value === null || value === undefined(但更推荐直接写后者)
  • 处理某些老 API 返回值类型不确定,且你确信转换逻辑符合预期(极少)

额外提醒:Object 和特殊值的比较

注意:无论是 == 还是 ===对象(包括数组、函数)比较的都是引用地址,不是内容:

  • [1,2] == [1,2]false
  • [1,2] === [1,2]false
  • NaN == NaNfalseNaN 不等于任何值,包括自己;=== 同样如此)
  • 判断 NaN 应该用 Number.isNaN()isNaN()
text=ZqhQzanResources