等于和绝对等于的区别

1. ==(等于)

  • 特点:比较时会自动进行类型转换(隐式转换),尝试将两边的值转为相同类型后再比较。
  • 规则
    • 如果类型相同,直接比较值。
    • 如果类型不同,按以下规则转换:
      • 数字 vs 字符串:字符串转数字。
      • 布尔值 vs 非布尔值:布尔值转数字(true1false0)。
      • 对象 vs 基本类型:调用对象的 valueOf()toString() 转为基本类型。
      • nullvsundefined:视为相等。

2. ===(绝对等于/严格等于)

  • 特点:不进行类型转换,直接比较类型和值。
  • 规则
    • 如果类型不同,直接返回 false
    • 如果类型相同,再比较值。

|-----------------------|------------------|---------------------|---------------------|
| 场景 | ==****(等于)结果 | ===****(绝对等于)结果 | 原因说明 |
| 5 == '5' | true | false | == 会转换类型为数字再比较 |
| 0 == false | true | false | false 转为 0 |
| '' == 0 | true | false | 空字符串转为 0 |
| null == undefined | true | false | 特殊规则 |
| NaN == NaN | false | false | NaN 不等于任何值,包括自身 |
| {} == {} | false | false | 对象比较的是引用地址 |

相关推荐
大怪v几秒前
【创世界01】头脑热一把,我要带你纯前端手搓虚拟世界💪!
javascript·css·html
code_Bo15 分钟前
使用micro-app 多层嵌套的问题
前端·javascript·架构
小灰15 分钟前
VS Code 插件 Webview 热更新配置
前端·javascript
八哥程序员22 分钟前
深入理解 JavaScript 作用域与作用域链
前端·javascript
Yanni4Night30 分钟前
数据可视化神器Heat.js:让你的数据热起来
前端·javascript
Funny Valentine-js37 分钟前
web实验后端php测试文本
前端·javascript·php·html5·cookie·telnet·session
DevUI团队1 小时前
解锁前端高阶调试:浏览器/IDE/Git技巧分享
前端·javascript·html
CoolerWu1 小时前
Trae Solo 实战指南:从"会用"到"用好"的协作方法论
前端·javascript
鹏多多1 小时前
轻量+响应式!React瀑布流插件react-masonry-css的详细教程和案例
前端·javascript·react.js
一颗宁檬不酸1 小时前
Vue.js 初学者基础知识点总结 第一弹
前端·javascript·vue.js