隐式转换的细节:别再这样if判断对象有没有该属性了!

今天在网上看到一个关于 ((2==true) + 1) 输出多少的问题,我直接就回答2了,然鹅。。。

js 复制代码
((2==true) + 1)  // 1

why??2==true不是1吗,1+1不是2吗。前者的思考是我对if语法判断的误解,因为以前if判断某个对象是否存在一个属性的时候,只要他有值,那就为真,然后就把2当做true了。后面查阅资料后发现,if判断会将判断条件强转为布尔值,要是以此来判断某个对象是否存在一个属性,那这里面就有很多坑了。

js转布尔值有下面四种情况:

  1. 数字→布尔,0和NaN结果是false 其他都是true
  2. 字符串→布尔,空字符串为false,其他都为true,包括空格字符串" "和"0"
  3. null和undefined都会转为false
  4. 引用数据类型都会转为true,包括空数组[]和空对象{}

测试案例:

实际开发中再这样写if代码判断直接得挨开发组长骂了

结论:推荐的判断对象属性的方法还是使用obj.hasOwnProperty(propertyName),这个方法不会顺着原型链查找属性,如果需要查找可以用in操作符


回到最初的那个问题,(2==true)跟if(obj.a)是否有差别呢,答案是,大大的差别。

if判断是直接转布尔类型判断,而双等号的隐式转换规则就多了。

  1. 先看两边有没有NaN,有的话直接返回false
  2. 再看两边有没有布尔值,有就布尔值转数字(true为1,false为0)
  3. 最后看两边有没有字符串又分三种情况。如果对方是对象,则转为字符串(数组会直接转成对应序列字符串,对象会转成'[object Object]');如果对方是数字,字符串转数字(也跟第二点有关);如果对方是字符串,直接比较

这时看最初的那个问题,不就明朗起来了~

((2==true)+1)的隐式转换步骤:

  1. true转为1
  2. 2==true返回false
  3. false+1也进行隐式转换,false转为0
  4. 0+1=1

拓展问题:[ ] == ![ ] 输出什么?

没错,输出的居然是true!!![ ]转字符串是"" 转布尔值是true,这是两个极端。

  1. 先进行布尔转换, ([ ] == ![ ]) ==> ([ ] == false) ==> ([ ] == 0)
  2. 空数组转字符串, ( "" == 0 ) 开始看得出结果了
  3. 字符串转数字, 0 == 0

参考资料:

  1. blog.csdn.net/ximing02071...
  2. www.php.cn/faq/397193....
  3. blog.csdn.net/Leslie_hxd/...
相关推荐
_AaronWong13 小时前
Electron 实现仿豆包划词取词功能:从 AI 生成到落地踩坑记
前端·javascript·vue.js
cxxcode13 小时前
I/O 多路复用:从浏览器到 Linux 内核
前端
用户54330814419414 小时前
AI 时代,前端逆向的门槛已经低到离谱 — 以 Upwork 为例
前端
JarvanMo14 小时前
Flutter 版本的 material_ui 已经上架 pub.dev 啦!快来抢先体验吧。
前端
JohnYan14 小时前
工作笔记-CodeBuddy应用探索
javascript·ai编程·aiops
恋猫de小郭14 小时前
AI 可以让 WIFI 实现监控室内人体位置和姿态,无需摄像头?
前端·人工智能·ai编程
哀木14 小时前
给自己整一个 claude code,解锁编程新姿势
前端
程序员鱼皮14 小时前
GitHub 关注突破 2w,我总结了 10 个涨星涨粉技巧!
前端·后端·github
UrbanJazzerati14 小时前
Vue3 父子组件通信完全指南
前端·面试
是一碗螺丝粉14 小时前
5分钟上手LangChain.js:用DeepSeek给你的App加上AI能力
前端·人工智能·langchain