前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >js中关于假值和空数组的总结

js中关于假值和空数组的总结

作者头像
IT人一直在路上
发布2019-09-18 10:47:35
5.1K0
发布2019-09-18 10:47:35
举报
文章被收录于专栏:前端重点笔记

先上x==y运算符的算法细节:

  1. 如果x不是正常值(比如抛出一个错误),中断执行。
  2. 如果y不是正常值,中断执行。
  3. 如果Type(x)Type(y)相同,执行严格相等运算x === y
  4. 如果xnullyundefined,返回true
  5. 如果xundefinedynull,返回true
  6. 如果Type(x)是数值,Type(y)是字符串,返回x == ToNumber(y)的结果。
  7. 如果Type(x)是字符串,Type(y)是数值,返回ToNumber(x) == y的结果。
  8. 如果Type(x)是布尔值,返回ToNumber(x) == y的结果。
  9. 如果Type(y)是布尔值,返回x == ToNumber(y)的结果。
  10. 如果Type(x)是字符串或数值或Symbol值,Type(y)是对象,返回x == ToPrimitive(y)的结果。
  11. 如果Type(x)是对象,Type(y)是字符串或数值或Symbol值,返回ToPrimitive(x) == y的结果。
  12. 返回false

1、“假值”总共只有6个: false,undefined,null,0,""(空字符串),NaN 除此之外的所有值,都是“真值”,即在逻辑判断中可以当true来使用

用代码表示:

代码语言:javascript
复制
if(false&&undefined&&null&&0&&""&&NaN){
    console.log('其中有真值');
}else{
    console.log('全部都是假值');
}
//全部都是假值

2、对于空数组和空对象的疑惑

疑惑来源:用空数组和空对象进行if语句判断为true,但是空数组和true进行==运算时,返回的是false

用代码表示:

代码语言:javascript
复制
if([]){
    console.log('空数组转化为布尔值为true');//空数组转化为布尔值为true
}
if({}){
    console.log('空对象转化为布尔值为true');//空对象转化为布尔值为true
}
if([]==true){
    console.log('空数组等于true');
}else{
    console.log('空数组等于false');//空数组等于false
}

为什么空数组转化为布尔值是true,而下面和true做对比时又不等于true呢?

原因分析:if ([ ]) {} 里发生自动类型转换,[ ] => Boolean,从object到布尔型,结果是true。事实上,所有的object转型到Boolean,都是true,[ ]和{ }都是对象。

      [ ] == true 里不发生自动类型转换,这条语句只比较左右的“值”是否相等,所以要先化为number类型,true转化为数字1就不用说了,主要分析一下[ ]怎么转化为0的,这里涉及到ToPrimitive方法的操作,不懂的可以先看我的另一篇博客,https://i.cnblogs.com/EditPosts.aspx?postid=10859000,再返回看。[ ]会先调用valueOf方法,返回数组本身不是原始值,所以继续调用toString方法,返回' ',从而Number(' ')=0,而0!=1,所以返回false。

总结:Boolean([ ]) => true;//直接作条件    Boolean(Number([ ])) => false;//当与布尔值做比较时

Number({ })//NaN,不等于任何数包括自己

最后送大家一张经典的图:

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-04-30 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档