等于和绝对等于的区别

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

相关推荐
阿猫的故乡2 小时前
Vue过渡动画从入门到装X:淡入淡出、滑动、列表动画、第三方库全搞定
前端·javascript·vue.js
小和尚敲木头2 小时前
vue3 vite动态拼接图片路径
javascript
我叫黑大帅3 小时前
前端如何竖屏固定视口背景
前端·javascript·面试
不会敲代码13 小时前
我花了三天时间,终于把 Cookie、XSS、CSRF 和浏览器存储给整明白了
javascript·面试
贩卖黄昏的熊3 小时前
flex 布局快速梳理
开发语言·javascript·css3·html5
swipe3 小时前
Mem0 x Agent 实战系列:分层记忆 + 三路召回,搭建真正可用的长期记忆层
前端·javascript·面试
kyriewen4 小时前
手写 call、apply、bind:从原理到实现,附 3 个最容易忽略的边界情况
前端·javascript·面试
胡萝卜术4 小时前
从内存视角重新认识 JavaScript 数据类型:一份深度学习笔记
前端·javascript·面试
LiuJun2Son5 小时前
Angular 快速入门:从零搭建你的第一个应用
前端·javascript·angular.js
烬羽5 小时前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构