等于和绝对等于的区别

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 分钟前
Cookie与Session:Web开发中的身份验证与数据存储
前端·javascript·面试
成遇1 小时前
Eslint基础使用
javascript·typescript·es6
前端小趴菜056 小时前
React-React.memo-props比较机制
前端·javascript·react.js
RadiumAg9 小时前
记一道有趣的面试题
前端·javascript
yangzhi_emo9 小时前
ES6笔记2
开发语言·前端·javascript
yanlele9 小时前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试
烛阴11 小时前
void 0 的奥秘:解锁 JavaScript 中 undefined 的正确打开方式
前端·javascript
初遇你时动了情11 小时前
腾讯地图 vue3 使用 封装 地图组件
javascript·vue.js·腾讯地图
dssxyz11 小时前
uniapp打包微信小程序主包过大问题_uniapp 微信小程序时主包太大和vendor.js过大
javascript·微信小程序·uni-app
ohMyGod_12313 小时前
React16,17,18,19新特性更新对比
前端·javascript·react.js