成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何在JavaScript中將數值轉換為Boolean

開發 前端
JavaScript中如何將數值轉換為Boolean?這篇文章幫你搞定!往下看吧。

本文轉載自公眾號“讀芯術”(ID:AI_Discovery)

JavaScript中如何將數值轉換為Boolean?這篇文章幫你搞定!往下看吧~

[[321184]]

字符串

  1. conststring = 'string';!!string; // true 
  2. Boolean(string); // true 

數值

  1. constnumber = 100;!!number; // true 
  2. Boolean(number); // true 

虛值

在JavaScript中,有6個虛值。如果將其中任何一個字符串轉換為Boolean,它將變為false 。

  1. false 
  2. undefined 
  3. null 
  4. NaN 
  5. "" (empty string) 

任何不為虛值的都會轉換為true。

示例

虛值的應用:

  1. !!false;// false 
  2. !!undefined; // false 
  3. !!null; // false 
  4. !!NaN; // false 
  5. !!0; // false 
  6. !!''; // false 

虛值在Boolean上下文中的應用:

  1. Boolean(false);// false 
  2. Boolean(undefined); // false 
  3. Boolean(null); // false 
  4. Boolean(NaN); // false 
  5. Boolean(0); // false 
  6. Boolean(''); // false 

當心 ‘false’

  1. constvalue = 'false';!!value; // true 
  2. Boolean(value); // true 

注意“false”必須寫在引號之間。雖然是虛值,但實際上是一個字符串。大多數人都不會在這里中圈套,但還是需要隨時保持警惕。

如何在JavaScript中將數值轉換為Boolean

圖源:digilentin

如何操作該代碼

首先! 將該值強制轉換為Boolean并取反。在上下文中, !value將變回虛值。所以為了將value恢復成真值,將另一個“!” 放入操作中,因此這里出現了兩個!。

  1. const value = 'string';!value; //false!!value; // true 

速度測試

boolean vs !!

看起來像 !! 但測試速度比Boolean快。

[[321186]]

圖源:unsplash

有些人更喜歡Boolean,因為它更明確。但是,KyleSimpson在《你不知道的JavaScript》中提到,這兩者都是明確的。

  1. //better (works explicitly): 
  2. if (!!a) { 
  3. }// also great (works explicitly): 
  4. if (Boolean(a)) { 

這里不會給你標準答案,你可以按需選擇。筆者會在個人開發的項目中繼續使用!!,其鍵入較少而且筆者對這種語法有了解。

反之,如果是作為團隊考慮,筆者可能會選擇Boolean。大多數開發人員都能更好地理解這一點。無論選擇哪一個,最重要的是保持代碼一致,不要換來換去,選擇一種并堅持下去。

這更像是一種偏好選擇,不要剝奪自己理解兩種代碼的權利。

避免newBoolean

使用基元而不是對象類型

  1. var str = 'str';// Avoid 
  2. typeof new Boolean(str); // object// Preferred 
  3. typeof Boolean(str); // boolean 
  4. typeof !!str; // boolean 

值得注意的是,new Boolean不是boolean,而是布爾值的示例。基元比較廉價,相比對象類型應優先使用。

new Boolean(str) 可以返回對象類型。Boolean(str)只返回boolean的原始值。筆者猜測Boolean(str)比!!str更快。因為這只是一項操作,但是瀏覽器也有可能實施優化,以便程序員看到 !! 他們知道直接將參數轉換為boolean原始值(而不是實際執行NOT()連續兩次)。

基元很便宜,它們是不可變的,因此可以共享引用,而不必在實例上保留任何狀態。要么true要么false。

但newBoolean(str)是一個對象。它有自己的唯一存儲地址,并且可以保存唯一的內部狀態。這意味著它不能只保存對不可變單例實例的引用。每次運行new Boolean(str) 實例化都會產生一個全新的Boolean()對象。

使用Boolean構造函數刪除空字符串

CJJ.:這是經典示例。如果得到一個用逗號分隔的字符串值列表,并且想要過濾掉空字符串,則可以將Boolean構造函數傳遞給Array.prototype.filter,它將自動去除零長度字符串,而僅保留一個有效的字符串數組。

  1. var str'some,list,,of,values'
  2. var arr = str.split(',');arr; // [ 'some', 'list', '', 'of', 'values']arr.filter(Boolean); // [ 'some', 'list', 'of', 'values' ] 

你學會了嗎?

 

責任編輯:趙寧寧 來源: 讀芯術
相關推薦

2022-12-25 16:15:38

HTMLJava可視化文檔

2022-12-25 15:56:30

JavaScript字符串

2021-12-29 07:56:32

Go byte io.Reader

2016-11-15 14:29:14

Linux文件編碼轉換

2015-11-24 09:53:22

AngularJSXMLJSON

2022-09-22 11:40:11

JavaScript數組開發

2024-09-18 08:00:05

C#編程

2023-10-16 09:26:48

CSS類型轉換

2024-03-12 07:35:39

Python字符串列表

2021-10-29 15:13:21

LinuxPDF文件

2015-09-14 14:49:39

MySQLMariaDBLinux

2009-12-01 14:00:37

PHP字符串轉換為數值

2022-05-31 10:38:50

Linux密碼scp

2021-06-07 12:20:14

LinuxASCII命令

2020-03-06 08:56:41

Linux運算符文本

2022-12-19 15:28:31

JavaScrip字符串

2021-08-26 09:46:22

JavaScript字符串URL

2022-12-22 09:00:00

微服務架構

2019-08-21 13:30:25

Node.jsSVG前端

2021-03-11 23:43:20

JavaScript數組開發
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产人成精品一区二区三 | 欧美精品电影一区 | 北条麻妃一区二区三区在线观看 | 热99精品视频| 91在线网 | 99re在线视频| 国产传媒在线播放 | 亚洲成人自拍 | 精品videossex高潮汇编 | 久久草在线视频 | 超碰日本 | 一级黄色片美国 | 精品国产一区二区三区在线观看 | 欧美精品导航 | 成人黄色在线 | 91久久精品一区二区二区 | 午夜久久久久久久久久一区二区 | 97国产超碰 | 在线观看午夜视频 | 最新日韩欧美 | 福利一区二区在线 | 欧美久久一级特黄毛片 | 玖玖国产精品视频 | 精品一区二区三区中文字幕 | 国产精品自拍一区 | 日韩成人在线视频 | 免费一级淫片aaa片毛片a级 | 丁香一区二区 | 成人在线视频免费播放 | 成人日韩av | 久久噜噜噜精品国产亚洲综合 | 日韩视频在线免费观看 | 激情五月婷婷在线 | 玖草资源 | 欧美激情视频一区二区三区免费 | 91亚洲视频在线 | 亚洲欧美少妇 | 国产一级在线视频 | av手机免费在线观看 | 成人欧美一区二区三区色青冈 | 久久成人18免费网站 |