前言:
相信我們程序員平時寫代碼用的最多的邏輯就是if語句了吧,可你知道他的原理是什么嗎,其實這跟Boolean()這個方法有關(guān),此方法為自動執(zhí)行(在需要判定Boolean的語句中中自動執(zhí)行),這些轉(zhuǎn)換規(guī)則對理解if控制語句自動執(zhí)行相應的Boolean轉(zhuǎn)換非常重要,
這是我們平時所寫的代碼
var a = "auto" if(a){ console.log("執(zhí)行") }
其實執(zhí)行起來是這樣,理解一下
var a = "auto" if(Boolean(a)){ console.log("執(zhí)行") }
這樣其實就好理解了,每個類型的值其實都可以轉(zhuǎn)換為Boolean值,有一定的規(guī)則,接下來我們看看具體操作
取證將需要轉(zhuǎn)換的數(shù)據(jù)傳遞給Boolean()函數(shù)
Boolean: 毋庸置疑true就是true,false就是false,但是new Boolean這里有坑
var boolean1 = true; // true; var boolean2 = false; // false; console.log(Boolean(boolean1)); console.log(Boolean(boolean2));
// 這里坑來了 Boolean()是返回布爾值,new Boolean()是返回布爾對象(對象里面的值為false,)
var x = Boolean(false); if (x) { // 這里的代碼不會被執(zhí)行 } var x = new Boolean(false); if (x) { // 這里的代碼會被執(zhí)行 }
注意不要將基本類型中的布爾值 true 和 false 與值為 true 和 false 的 Boolean 對象弄混了。不要在應該使用基本類型布爾值的地方使用 Boolean 對象。
var x = Boolean(expression); // 推薦(Boolean值) var x = new Boolean(expression); // 不推薦,Boolean對象里的值不管是true還是false,只要對象有值都會判定為true,if語句中都會執(zhí)行、
String: 只要不是空字符串(沒有任何內(nèi)容),任何非空字符串(包含空格) 都會轉(zhuǎn)換為true
var str1 = ""; // "" --> false var str2 = " "; // " " --> true; var str3 = "abc"; // " " --> true; console.log(Boolean(str1)); console.log(Boolean(str2)); console.log(Boolean(str3));
Number: 只有0和NaN會轉(zhuǎn)換為false,其他都會轉(zhuǎn)換為true
var num1 = 0; //false var num2 = -1; //true var num3 = 1; //true var num4 = NaN; //false console.log(Boolean(num1)); console.log(Boolean(num2)); console.log(Boolean(num3));
null、undefined: 都會轉(zhuǎn)換為false
var n = null; //false var u = undefined; //false console.log(Boolean(n)); console.log(Boolean(u));總結(jié):
false / "" / NaN / 0 / null / undefined 都會轉(zhuǎn)換為 false
注意 Boolean() 和 new Boolean()的區(qū)別參考:
前者生成布爾值,后者生成布爾對象,后者不推薦使用
大部分取經(jīng)于js高程紅寶書26頁,3.4.4章節(jié)(Boolean類型的介紹)
new Boolean()的坑取經(jīng)于MDN中Boolean的描述
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/103719.html
摘要:如圖意義位用來表示符號位位用來表示指數(shù)位表示尾數(shù)浮點數(shù),比如無限循環(huán)無限循環(huán)此時只能模仿十進制進行四舍五入了,但是二進制只有和兩個,于是變?yōu)樯崛?。這即是計算機中部分浮點數(shù)運算時出現(xiàn)誤差,丟失精度的根本原因。 showImg(http://ww1.sinaimg.cn/large/9c47d583gy1fmtw1ma9g4j21hc0u0ach.jpg); 前言 最近一直有小伙伴跟我說J...
摘要:一彈窗和輸出執(zhí)行順序是從上到下執(zhí)行控制瀏覽器彈出一個警告框讓計算機在頁面中輸出一個內(nèi)容在中寫一個內(nèi)容寫可以向中輸出一個內(nèi)容看我出不出來向控制臺輸出一個內(nèi)容作用是向控制臺輸出一個內(nèi)容你猜我在哪出來二編寫位置可以將代碼編寫到外部文件中,然后通過 一.彈窗和輸出 **javascript執(zhí)行順序是從上到下執(zhí)行** 1.控制瀏覽器彈出一個警告框 alert(HelloWord); 2.讓計...
摘要:基本數(shù)據(jù)類型在中,基本數(shù)據(jù)類型有種,即數(shù)值字符串布爾值。兩個布爾值轉(zhuǎn)為數(shù)值進行比較。對于對象和布爾值,調(diào)用它們的方法得到對應的字符串值,然后進行字符串相加。減法對于字符串布爾值或者,自動調(diào)用,轉(zhuǎn)換結(jié)果若為,那么最終結(jié)果為。 這篇文章,來聊聊 JS 中的數(shù)據(jù)類型與變量。這是在學習 JS 時最基礎的一類問題,但卻很重要。希望我的分享有幫助到你。 文章開頭,我先提幾個面試中遇到的問題: 比如...
摘要:目錄語句變量小結(jié)基本語法一是核心知識點的基本語法的第一部分,主要介紹了語句表達式變量和數(shù)據(jù)類型不包括函數(shù)類型的基本知識點,函數(shù)類型將在下一章函數(shù)二中詳細探討語句程序的執(zhí)行是由一條條語句組成的每一條語句是為完成特定任務而執(zhí)行的操作語句當中可以 目錄 1. 語句 2. 變量 3. 小結(jié) JavaScript基本語法(一)是JavaScript核心知識點(ECMAScript)的基本語法的...
閱讀 1287·2023-04-25 20:31
閱讀 3779·2021-10-14 09:42
閱讀 1562·2021-09-22 16:06
閱讀 2761·2021-09-10 10:50
閱讀 3621·2021-09-07 10:19
閱讀 1865·2019-08-30 15:53
閱讀 1243·2019-08-29 15:13
閱讀 2887·2019-08-29 13:20