登录
首页 >  文章 >  前端

==与===区别:JavaScript相等性对比解析

时间:2026-01-21 20:45:45 333浏览 收藏

小伙伴们对文章编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《==与===区别详解:JavaScript相等比较全解析》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

===要求值和类型都相同,不转换类型;==会强制类型转换后再比较,易产生反直觉结果,如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。只有极少数场景才考虑 ==

  • 明确需要兼容 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()

好了,本文到此结束,带大家了解了《==与===区别:JavaScript相等性对比解析》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>