首页 > JavaScript中为什么空数组的布尔值为true(即为什么!![];//true)?

JavaScript中为什么空数组的布尔值为true(即为什么!![];//true)?

JavaScript中空数组的布尔值为何为真?空数组是一个对象,那对象的布尔值就都是true了?


没有为什么,记住就对了。


我就想说一下{}和null的区别,

    console.log(typeof null);
    console.dir({});
    console.dir(null);

{}是一个不完全空的对象,因为他的原型链上还有Object呢,而null就是完全空的对象,啥也没有,原型链也没有,所以null instanceof Object === false;[]就更不用说了,它的原型链上还比{}多一个Array。
所以,纯粹意义上初始化一个空对象应该用null,{}更像是初始化对象,和new一个没有key的Obejct是一样的。


boolean转换规则如下

数据类型 转换为true的值 转换为false的值
Boolean true false
String 任何非空字符串 ""空字符串
Number 任何非0数字值(包括无穷大) 0和NaN
Object 任何对象 null
Undefined n/a undefined

楼主自己已经给出了答案,很棒啊。
不过向大家推荐这个表,通熟易懂。


判断数组要判断长度 [].length > 0


所有的对象(null不算,虽然typeof null 是object)转换成布尔值都是true
如果你真的希望理解内部的转换,又不想去找ecma的东西。仍一篇文章送给你http://goddyzhao.tumblr.com/post/13962242607/why-is-this-condition-true


你说的对,就是因为:

数组(不管是不是空的)属于对象类型,对象类型转为boolean类型(内部对应ToBoolean()操作)时都是true。


不能简单地认为空数组是真还是假,比如:

[] == false // true
![]  // false

参考 http://es5.github.io/#x11.4.9 ,! 算符是根据 ToBoolean 算法再取反,ToBoolean 算法将包含空数组在内的 Object 当作真值;而采用 == 算符比较时则会用 ToNumber 算法,ToNumber 算法则将空数组转为 0,也就是一个假值……而上面用 == 比较的情况等价于 ToPrimitive([]) == ToNumber(false),此时空数组看起来像假值。


var array = []
if(array) // 返回true,因为array是一个非空对象
if(!!array) // !!双重否定 表示肯定 if(array) 等于 if(!!array) 等于!![] 所以返回true

要判断数组是否为空 应该用 array.length, !![]并不是用来判断数组是否为空的,在实际的应用场景中几乎用不到

【热门文章】
【热门文章】