JavaScript中如何將數(shù)值轉(zhuǎn)換為Boolean,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
成都創(chuàng)新互聯(lián)為客戶提供專業(yè)的網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站設(shè)計(jì)、程序、域名、空間一條龍服務(wù),提供基于WEB的系統(tǒng)開發(fā). 服務(wù)項(xiàng)目涵蓋了網(wǎng)頁設(shè)計(jì)、網(wǎng)站程序開發(fā)、WEB系統(tǒng)開發(fā)、微信二次開發(fā)、手機(jī)網(wǎng)站制作設(shè)計(jì)等網(wǎng)站方面業(yè)務(wù)。
字符串
conststring = 'string';!!string; // true
Boolean(string); // true
在這里小編建了一個(gè)前端學(xué)習(xí)交流扣扣群:132667127,我自己整理的最新的前端資料和高級(jí)開發(fā)教程,如果有想需要的,可以加群一起學(xué)習(xí)交流
數(shù)值
constnumber = 100;!!number; // true
Boolean(number); // true
虛值
在JavaScript中,有6個(gè)虛值。如果將其中任何一個(gè)字符串轉(zhuǎn)換為Boolean,它將變?yōu)閒alse 。
false
undefined
null
NaN
0
"" (empty string)
任何不為虛值的都會(huì)轉(zhuǎn)換為true。
示例
虛值的應(yīng)用:
!!false;// false
!!undefined; // false
!!null; // false
!!NaN; // false
!!0; // false
!!''; // false
虛值在Boolean上下文中的應(yīng)用:
Boolean(false);// false
Boolean(undefined); // false
Boolean(null); // false
Boolean(NaN); // false
Boolean(0); // false
Boolean(''); // false
當(dāng)心 ‘false’
constvalue = 'false';!!value; // true
Boolean(value); // true
注意“false”必須寫在引號(hào)之間。雖然是虛值,但實(shí)際上是一個(gè)字符串。大多數(shù)人都不會(huì)在這里中圈套,但還是需要隨時(shí)保持警惕。
圖源:digilentin
如何操作該代碼
首先! 將該值強(qiáng)制轉(zhuǎn)換為Boolean并取反。在上下文中, !value將變回虛值。所以為了將value恢復(fù)成真值,將另一個(gè)“!” 放入操作中,因此這里出現(xiàn)了兩個(gè)!。
const value = 'string';!value; //false!!value; // true
速度測試
boolean vs !!
看起來像 !! 但測試速度比Boolean快。
圖源:unsplash
有些人更喜歡Boolean,因?yàn)樗鞔_。但是,KyleSimpson在《你不知道的JavaScript》中提到,這兩者都是明確的。
//better (works explicitly):
if (!!a) {
}// also great (works explicitly):
if (Boolean(a)) {
}
這里不會(huì)給你標(biāo)準(zhǔn)答案,你可以按需選擇。筆者會(huì)在個(gè)人開發(fā)的項(xiàng)目中繼續(xù)使用!!,其鍵入較少而且筆者對(duì)這種語法有了解。
反之,如果是作為團(tuán)隊(duì)考慮,筆者可能會(huì)選擇Boolean。大多數(shù)開發(fā)人員都能更好地理解這一點(diǎn)。無論選擇哪一個(gè),最重要的是保持代碼一致,不要換來換去,選擇一種并堅(jiān)持下去。
這更像是一種偏好選擇,不要?jiǎng)儕Z自己理解兩種代碼的權(quán)利。
避免newBoolean
使用基元而不是對(duì)象類型
var str = 'str';// Avoid
typeof new Boolean(str); // object// Preferred
typeof Boolean(str); // boolean
typeof !!str; // boolean
CJJ.:值得注意的是,new Boolean不是boolean,而是布爾值的示例?;容^廉價(jià),相比對(duì)象類型應(yīng)優(yōu)先使用。
CJJ.:new Boolean(str) 可以返回對(duì)象類型。Boolean(str)只返回boolean的原始值。筆者猜測Boolean(str)比!!str更快。因?yàn)檫@只是一項(xiàng)操作,但是瀏覽器也有可能實(shí)施優(yōu)化,以便程序員看到 !! 他們知道直接將參數(shù)轉(zhuǎn)換為boolean原始值(而不是實(shí)際執(zhí)行NOT()連續(xù)兩次)。
CJJ.:基元很便宜,它們是不可變的,因此可以共享引用,而不必在實(shí)例上保留任何狀態(tài)。要么true要么false。
但newBoolean(str)是一個(gè)對(duì)象。它有自己的唯一存儲(chǔ)地址,并且可以保存唯一的內(nèi)部狀態(tài)。這意味著它不能只保存對(duì)不可變單例實(shí)例的引用。每次運(yùn)行new Boolean(str) 實(shí)例化都會(huì)產(chǎn)生一個(gè)全新的Boolean()對(duì)象。
使用Boolean構(gòu)造函數(shù)刪除空字符串
CJJ.:這是經(jīng)典示例。如果得到一個(gè)用逗號(hào)分隔的字符串值列表,并且想要過濾掉空字符串,則可以將Boolean構(gòu)造函數(shù)傳遞給Array.prototype.filter,它將自動(dòng)去除零長度字符串,而僅保留一個(gè)有效的字符串?dāng)?shù)組。
var str= 'some,list,,of,values';
var arr = str.split(',');arr; // [ 'some', 'list', '', 'of', 'values']arr.filter(Boolean); // [ 'some', 'list', 'of', 'values' ]
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。
網(wǎng)頁題目:JavaScript中如何將數(shù)值轉(zhuǎn)換為Boolean
文章起源:http://www.rwnh.cn/article0/ippdio.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、企業(yè)網(wǎng)站制作、Google、外貿(mào)建站、App設(shè)計(jì)、響應(yīng)式網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)