等于和绝对等于的区别

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 | 对象比较的是引用地址 |

相关推荐
D_C_tyu1 小时前
Vue3 + Element Plus | el-table 表格获取排序后的数据
javascript·vue.js·elementui
天外天-亮2 小时前
v-if、v-show、display: none、visibility: hidden区别
前端·javascript·html
沿着路走到底3 小时前
JS事件循环
java·前端·javascript
子春一24 小时前
Flutter 2025 可访问性(Accessibility)工程体系:从合规达标到包容设计,打造人人可用的数字产品
前端·javascript·flutter
jlspcsdn5 小时前
20251222项目练习
前端·javascript·html
拉不动的猪7 小时前
回顾计算属性的缓存与监听的触发返回结果
前端·javascript·vue.js
树欲静而风不止慢一点吧7 小时前
小米手环9应用/游戏开发快速入门
前端·javascript·小程序
用户313050086277 小时前
JavaScript中的迭代器和生成器
javascript
Crystal3287 小时前
图片懒加载
前端·javascript·代码规范