成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

js中if判斷語句執(zhí)行原因--數(shù)據(jù)類型轉(zhuǎn)換原理

RyanQ / 2737人閱讀

前言:

相信我們程序員平時寫代碼用的最多的邏輯就是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

相關(guān)文章

  • JavaScript 基礎知識 - 入門篇(一)

    摘要:如圖意義位用來表示符號位位用來表示指數(shù)位表示尾數(shù)浮點數(shù),比如無限循環(huán)無限循環(huán)此時只能模仿十進制進行四舍五入了,但是二進制只有和兩個,于是變?yōu)樯崛?。這即是計算機中部分浮點數(shù)運算時出現(xiàn)誤差,丟失精度的根本原因。 showImg(http://ww1.sinaimg.cn/large/9c47d583gy1fmtw1ma9g4j21hc0u0ach.jpg); 前言 最近一直有小伙伴跟我說J...

    sarva 評論0 收藏0
  • javascript基礎

    摘要:一彈窗和輸出執(zhí)行順序是從上到下執(zhí)行控制瀏覽器彈出一個警告框讓計算機在頁面中輸出一個內(nèi)容在中寫一個內(nèi)容寫可以向中輸出一個內(nèi)容看我出不出來向控制臺輸出一個內(nèi)容作用是向控制臺輸出一個內(nèi)容你猜我在哪出來二編寫位置可以將代碼編寫到外部文件中,然后通過 一.彈窗和輸出 **javascript執(zhí)行順序是從上到下執(zhí)行** 1.控制瀏覽器彈出一個警告框 alert(HelloWord); 2.讓計...

    XFLY 評論0 收藏0
  • 分析 JavaScript 的數(shù)據(jù)類型與變量

    摘要:基本數(shù)據(jù)類型在中,基本數(shù)據(jù)類型有種,即數(shù)值字符串布爾值。兩個布爾值轉(zhuǎn)為數(shù)值進行比較。對于對象和布爾值,調(diào)用它們的方法得到對應的字符串值,然后進行字符串相加。減法對于字符串布爾值或者,自動調(diào)用,轉(zhuǎn)換結(jié)果若為,那么最終結(jié)果為。 這篇文章,來聊聊 JS 中的數(shù)據(jù)類型與變量。這是在學習 JS 時最基礎的一類問題,但卻很重要。希望我的分享有幫助到你。 文章開頭,我先提幾個面試中遇到的問題: 比如...

    Mike617 評論0 收藏0
  • JavaScript基本語法(一)

    摘要:目錄語句變量小結(jié)基本語法一是核心知識點的基本語法的第一部分,主要介紹了語句表達式變量和數(shù)據(jù)類型不包括函數(shù)類型的基本知識點,函數(shù)類型將在下一章函數(shù)二中詳細探討語句程序的執(zhí)行是由一條條語句組成的每一條語句是為完成特定任務而執(zhí)行的操作語句當中可以 目錄 1. 語句 2. 變量 3. 小結(jié) JavaScript基本語法(一)是JavaScript核心知識點(ECMAScript)的基本語法的...

    shiina 評論0 收藏0

發(fā)表評論

0條評論

閱讀需要支付1元查看
<