本文主要是介绍JavaScript各种基础对象:(3)包装对象之Boolean对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
1 Boolean对象
1.1 概述
1.2 Boolean实例对象的布尔值
1.3 Boolean函数的类型转换作用
1 Boolean对象
1.1 概述
Boolean对象是JavaScript的三个包装对象之一。作为构造函数,它主要用于生成布尔值的包装对象的实例。
var b = new Boolean(true);typeof b // "object"
b.valueOf() // true
上面代码的变量b是一个Boolean对象的实例,它的类型是对象,值为布尔值true。这种写法太繁琐,几乎无人使用,直接对变量赋值更简单清晰。
var b = true;
1.2 Boolean实例对象的布尔值
特别要注意的是,所有对象的布尔运算结果都是true。因此,false对应的包装对象实例,布尔运算结果也是true。
if (new Boolean(false)) {console.log("true");
} // trueif (new Boolean(false).valueOf()) {console.log("true");
} // 无输出
上面代码的第一个例子之所以得到true,是因为false对应的包装对象实例是一个对象,进行逻辑运算时,被自动转化成布尔值true(所有对象对应的布尔值都是true)。而实例的valueOf方法,则返回实例对应的原始类型值,本例为false。
1.3 Boolean函数的类型转换作用
Boolean对象除了可以作为构造函数,还可以单独使用,将任意值转为布尔值。这时Boolean就是一个单纯的工具方法。
Boolean(undefined) // false
Boolean(null) // false
Boolean(0) // false
Boolean('') // false
Boolean(NaN) // false
Boolean(1) // true
Boolean('false') // true
Boolean([]) // true
Boolean({}) // true
Boolean(function(){}) // true
Boolean(/foo/) // true
上面代码中几种得到true的情况,都值得认真记住。
使用not运算符(!)也可以达到同样效果
!!undefined // false
!!null // false
!!0 // false
!!'' // false
!!NaN // false
!!1 // true
!!'false' // true
!![] // true
!!{} // true
!!function(){} // true
!!/foo/ // true
综上所述,如果要获得一个变量对应的布尔值,有多种写法。
var a = "hello world";new Boolean(a).valueOf() // true
Boolean(a) // true
!!a // true
最后,对于一些特殊值,Boolean对象前面加不加new,会得到完全相反的结果,必须小心。
if (Boolean(false)) console.log('true'); // 无输出if (new Boolean(false))console.log('true'); // trueif (Boolean(null)) console.log('true'); // 无输出if (new Boolean(null))console.log('true'); // true
这篇关于JavaScript各种基础对象:(3)包装对象之Boolean对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!