JavaScript Boolean 對象

2023-03-20 15:55 更新

概述

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 函數(shù)的類型轉(zhuǎn)換作用

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


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號