W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
Boolean
對象是 JavaScript 的三個包裝對象之一。作為構(gòu)造函數(shù),它主要用于生成布爾值的包裝對象實例。
var b = new Boolean(true);
typeof b // "object"
b.valueOf() // true
上面代碼的變量b
是一個Boolean
對象的實例,它的類型是對象,值為布爾值true
。
注意,false
對應(yīng)的包裝對象實例,布爾運算結(jié)果也是true
。
if (new Boolean(false)) {
console.log('true');
} // true
if (new Boolean(false).valueOf()) {
console.log('true');
} // 無輸出
上面代碼的第一個例子之所以得到true
,是因為false
對應(yīng)的包裝對象實例是一個對象,進行邏輯運算時,被自動轉(zhuǎn)化成布爾值true
(因為所有對象對應(yīng)的布爾值都是true
)。而實例的valueOf
方法,則返回實例對應(yīng)的原始值,本例為false
。
Boolean
對象除了可以作為構(gòu)造函數(shù),還可以單獨使用,將任意值轉(zhuǎn)為布爾值。這時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
的情況,都值得認真記住。
順便提一下,使用雙重的否運算符(!
)也可以將任意值轉(zhuǎn)為對應(yīng)的布爾值。
!!undefined // false
!!null // false
!!0 // false
!!'' // false
!!NaN // false
!!1 // true
!!'false' // true
!![] // true
!!{} // true
!!function(){} // true
!!/foo/ // true
最后,對于一些特殊值,Boolean
對象前面加不加new
,會得到完全相反的結(jié)果,必須小心。
if (Boolean(false)) {
console.log('true');
} // 無輸出
if (new Boolean(false)) {
console.log('true');
} // true
if (Boolean(null)) {
console.log('true');
} // 無輸出
if (new Boolean(null)) {
console.log('true');
} // true
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: