javascript類型系統——布爾Boolean類型

来源:http://www.cnblogs.com/xiaohuochai/archive/2016/06/25/5616641.html
-Advertisement-
Play Games

× 目錄 [1]定義 [2]應用場景 [3]轉為布爾[4]實例方法 前面的話 布爾值Boolean類型可能是三種包裝對象Number、String和Boolean中最簡單的一種。Number和String對象擁有大量的實例屬性和方法,Boolean卻很少。從某種意義上說,為電腦設計程式就是與布爾值 ...


×
目錄
[1]定義 [2]應用場景 [3]轉為布爾[4]實例方法

前面的話

  布爾值Boolean類型可能是三種包裝對象Number、String和Boolean中最簡單的一種。NumberString對象擁有大量的實例屬性和方法,Boolean卻很少。從某種意義上說,為電腦設計程式就是與布爾值打交道,作為最基本的事實,所有的電子電路只能識別和使用布爾數據。本文將介紹布爾Boolean類型

 

定義

  布爾Boolean類型表示邏輯實體,它只有兩個值,保留字true和false,分別代表真和假這兩個狀態

  Boolean包裝類型是與布爾值對應的引用類型,在布爾表達式中使用Boolean對象容易造成誤解

var b1 = true;
var b2 = new Boolean(true);
console.log(b1,typeof b1);//true 'boolean'
console.log(b2,typeof b2);//Boolean{[[PrimitiveValue]]: true}  'object'
console.log(b1.valueOf(), typeof b1.valueOf());//true 'boolean'
console.log(b2.valueOf(), typeof b2.valueOf());//true 'boolean'

 

應用場景

  布爾類型主要應用於如下場景:

  【1】條件和迴圈語句

  布爾值主要應用於條件和迴圈語句的條件部分。比如,if語句中,如果布爾值為true執行第一段邏輯,如果為false執行另一段邏輯。通常將一個創建布爾值的比較直接與使用這個比較的語句結合在一起

if(a > 1){
    //條件為true時,執行此處
}else{
    //條件為false時,執行此處
}

  【2】邏輯運算符

  邏輯運算符又叫布爾運算符。邏輯非運算符總是返回布爾值,而邏輯或和邏輯與操作並非如此

  同時使用兩個邏輯非操作符,可以將類型轉換為布爾型

console.log(!!1);//true
console.log(!!0);//false
console.log(!!' ');//true
console.log(!!'');//false

  【3】關係運算符

  關係運算符用於測試兩個值之間的關係,根據關係是否存在而返回true或false,關係表達式總是返回一個布爾值,通常在if、while或for語句中使用關係表達式,用以控製程序的執行流程

console.log( 1 > 2);//false
console.log( 1 < 2);//true

 

轉為布爾

  將一個值轉為布爾值可使用Boolean()轉型函數

假值

  轉換成false的值稱為假值(falsy value),這7個值包括undefined、null、+0、-0、NaN、false、""(空字元串)

console.log(Boolean(undefined));//false
console.log(Boolean(null));//false
console.log(Boolean(0));//false
console.log(Boolean(-0));//false
console.log(Boolean(NaN));//false
console.log(Boolean(''));//false
console.log(Boolean(false));//false

  [註意]在Number()方法中空字元串和空白字元串都轉換為0,而在Boolean方法中,空字元串""轉換為false,而空白字元串" "轉換為true

console.log(Number(''));//0
console.log(Number(' '));//0

console.log(Boolean(''));//false
console.log(Boolean(' '));//true

  除了這7個假值外,其他的值轉換為布爾值都是true,也稱為真值(truthy value)

  [註意]所有對象(包括空對象)的轉換結果都是true,甚至連false對應的布爾對象new Boolean(false)也是true

console.log(Boolean({}));//true
console.log(Boolean([]));//true

console.log(Boolean(new Boolean(false)));//true
console.log(Boolean(false));//false
console.log(Boolean(new Boolean(null)));//true
console.log(Boolean(null));//false

 

實例方法

  Boolean對象是與布爾值對應的包裝類型,繼承了Object對象的通用方法toString()、toLocaleString()、valueOf()這三個方法

【toString()】

  toString()方法返回Boolean的字元串值('true'或'false')

【toLocaleString()】

  toLocaleString()方法返回Boolean的字元串值('true'或'false')

【valueOf()】

  valueOf()方法返回Boolean的原始布爾值(true或false)

console.log(true.valueOf());//true
console.log(true.toString());//'true'
console.log(true.toLocaleString());//'true'

console.log(Boolean(false).valueOf());//false
console.log(Boolean(false).toString());//'false'
console.log(Boolean(false).toLocaleString());//'false'

 

參考資料

【1】ES5/Boolean對象 https://www.w3.org/html/ig/zh/wiki/ES5/builtins
【2】阮一峰Javascript標準參考教程——語法概述 http://javascript.ruanyifeng.com/
【3】W3School-Javascript高級教程——Boolean對象 http://www.w3school.com.cn/
【4】《javascript權威指南(第6版)》第3章 類型、值和變數
【5】《javascript高級程式設計(第3版)》第3章 基本概念
【6】《javascript DOM編程藝術(第2版)》第2章 Javascript語法
【7】《javascript啟示錄》 第12章 Boolean()


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第一部分:用CSS實現佈局 讓我們一起來做一個頁面 首先,我們需要一個佈局。 請使用CSS控制3個div,實現如下圖的佈局。 第二部分:用javascript優化佈局 由於我們的用戶群喜歡放大看頁面 於是我們給上一題的佈局做一次優化。 當滑鼠略過某個區塊的時候,該區塊會放大25%, 並且其他的區塊仍 ...
  • 概述 觀察者模式又叫發佈 訂閱模式(Publish/Subscribe),它定義了一種一對多的關係,讓多個觀察者對象同時監聽某一個目標對象(為了方便理解,以下將觀察者對象叫做訂閱者,將目標對象叫做發佈者)。發佈者的狀態發生變化時就會通知所有的訂閱者,使得它們能夠自動更新自己。 觀察者模式的使用場合就 ...
  • 關於NPM: npm 是 nodejs 的包管理和分發工具。它可以讓 javascript 開發者能夠更加輕鬆的共用代碼和共用代碼片段,並且通過 npm 管理你分享的代碼也很方便快捷和簡單。 一 NodeJs安裝與NPM管理 安裝 前往NodeJs官網,下載安裝包直接安裝。同時NodeJs預設包含N ...
  • 本文收集了多本書里對JavaScript閉包(Closure)的解釋,或許會對理解閉包有一定幫助。 ...
  • 兩個數組合併與最大值最小值的獲取 //示例二 獲取最大值, var numbers = [5, 458, 120, -215]; var maxInNumbers = Math.max.apply(Math, numbers); //458 console.log("maxInNumbers:" + ...
  • × 目錄 [1]邏輯非 [2]邏輯與 [3]邏輯或 前面的話 邏輯運算符對操作數進行布爾運算,經常和關係運算符一樣配合使用。邏輯運算符將多個關係表達式組合起來組成一個更複雜的表達式。邏輯運算符分為邏輯非'!'、邏輯與'&&'、邏輯或'||'3種,本文將介紹這三種邏輯運算符 邏輯非 邏輯非操作符由一個 ...
  • HTML經過10多年的發展,其元素經歷了廢棄與不斷重新定義的過程。為了更好的處理現在的互聯網應用,HTML5新增了圖形繪製、多媒體播放、頁面結構、應用程式存儲、網路工作等新元素。http://hovertree.com/menu/html5/ 圖形繪製新元素 標簽描述 <canvas> 標簽定義圖形 ...
  • HTML5簡介 HTML5是HTML的最新修訂標準。2014年10月29日,萬維網聯盟(W3C)宣佈,經過8年的努力,HTML5標準規範制定完成。 HTML5的設計目的是在移動設備上使用多媒體。 HTML5簡單易學。 http://hovertree.com/menu/html5/ 什麼是HTML5 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...