亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript中的一些隱式轉(zhuǎn)換和總結(推薦)

 更新時間:2017年12月22日 16:15:57   作者:莫忘001  
這篇文章主要介紹了JavaScript中的一些隱式轉(zhuǎn)換和總結,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

js中的不同的數(shù)據(jù)類型之間的比較轉(zhuǎn)換規(guī)則如下:

1. 對象和布爾值比較

對象和布爾值進行比較時,對象先轉(zhuǎn)換為字符串,然后再轉(zhuǎn)換為數(shù)字,布爾值直接轉(zhuǎn)換為數(shù)字

[] == true; //false []轉(zhuǎn)換為字符串'',然后轉(zhuǎn)換為數(shù)字0,true轉(zhuǎn)換為數(shù)字1,所以為false

2. 對象和字符串比較

對象和字符串進行比較時,對象轉(zhuǎn)換為字符串,然后兩者進行比較。

[1,2,3] == '1,2,3' // true [1,2,3]轉(zhuǎn)化為'1,2,3',然后和'1,2,3', so結果為true;

3. 對象和數(shù)字比較

對象和數(shù)字進行比較時,對象先轉(zhuǎn)換為字符串,然后轉(zhuǎn)換為數(shù)字,再和數(shù)字進行比較。

[1] == 1; // true `對象先轉(zhuǎn)換為字符串再轉(zhuǎn)換為數(shù)字,二者再比較 [1] => '1' => 1 所以結果為true

4. 字符串和數(shù)字比較

字符串和數(shù)字進行比較時,字符串轉(zhuǎn)換成數(shù)字,二者再比較。

'1' == 1 // true

5. 字符串和布爾值比較

字符串和布爾值進行比較時,二者全部轉(zhuǎn)換成數(shù)值再比較。

'1' == true; // true

6. 布爾值和數(shù)字比較

布爾值和數(shù)字進行比較時,布爾轉(zhuǎn)換為數(shù)字,二者比較。

true == 1 // true

許多剛接觸js的童鞋看到這么多的轉(zhuǎn)換規(guī)則就懵圈了,其實規(guī)律很簡單,大家可以記下邊這個圖

如圖,任意兩種類型比較時,如果不是同一個類型比較的話,則按如圖方式進行相應類型轉(zhuǎn)換,如對象和布爾比較的話,對象 => 字符串 => 數(shù)值 布爾值 => 數(shù)值。
另外,我們來看下一些需要"特別照顧"的。

來看一個有趣的題

[] == false;
![] == false;

這兩個的結果都是true,第一個是,對象 => 字符串 => 數(shù)值0 false轉(zhuǎn)換為數(shù)字0,這個是true應該沒問題,
第二個前邊多了個!,則直接轉(zhuǎn)換為布爾值再取反,轉(zhuǎn)換為布爾值時,空字符串(''),NaN,0,null,undefined這幾個外返回的都是true, 所以! []這個[] => true 取反為false,所以[] == false為true。

還有一些需要記住的,像:

undefined == null //true undefined和null 比較返回true,二者和其他值比較返回false
Number(null) //0

曾經(jīng)看到過這樣一個代碼:  (!(~+[])+{})[--[~+""][+[]]*[~+[]]+~~!+[]]+({}+[])[[~!+[]*~+[]]] = sb , 你敢相信, 當時就嚇了 寶寶一跳。

剛接觸到時候,Js很讓我困惑,正是由于它‘善變',下面我來總結一下:

7. JS的數(shù)據(jù)類型: Number,Boolean,String,Undefined,Null,Symbol(es6新定義的)和 Object (注: Array是特殊的Object)

    typeof 返回的7中類型: number boolean string object undefined object function

MDN 這樣介紹Javascript: JavaScript 是一種弱類型或者說動態(tài)語言。這意味著你不用提前聲明變量的類型,在程序運行過程中,類型會被自動確定。這也意味著你可以使用同一個變量保存不同類型的數(shù)據(jù)

8. 下面來看下常見的隱式轉(zhuǎn)換:

  基本類型:

   運算符(+,-,*,/,%)操作時 轉(zhuǎn)換類型

    ”+“ 號運算符 :   

          

                    

      總結: 當加號運算符時,String和其他類型時,其他類型都會轉(zhuǎn)為 String;其他情況,都轉(zhuǎn)化為Number類型 , 注: undefined 轉(zhuǎn)化為Number是 為'NaN‘, 任何Number與NaN相加都為NaN。

          其他運算符時, 基本類型都轉(zhuǎn)換為 Number,String類型的帶有字符的比如: '1a' ,'a1' 轉(zhuǎn)化為 NaN 與undefined 一樣。

      tip:(1)NaN 不與 任何值相等 包括自身,所以判斷一個值 是否為 NaN, 即用 "!==" 即可?! ?/p>

         (2) 轉(zhuǎn)換為 Boolean類型為 false 的有:null,0,'',undefined,NaN,false  

       ?。?)number() 與 parseInt() 都可以將對象轉(zhuǎn)化為Number類型,Number函數(shù)要比parseInt函數(shù)嚴格很多?;旧?,只要有一個字符無法轉(zhuǎn)成數(shù)值,整個字符串就會被轉(zhuǎn)為NaN?! ?/p>

  

  Object類型

    當object與基本類型運算時:

var obj = {
  toString: function(){
    return 6;
  },
  valueOf: function(){
    return 5;
  }
};
var obj1 = {
  valueOf: function(){
    return 'a';
  },
  toString: function(){
    return 'b';
  }
};

           

                  

      

            當對 obj,obj1 用Number()和String()換轉(zhuǎn)時

        

            總結: Number類型會先調(diào)用valueOf(), String類型會先調(diào)用toString(),  如果結果是原始值,則返回原始值,否則繼續(xù)用toString 或 valueOf(),繼續(xù)計算,如果結果還不是原始值,則拋出一個類型錯誤; 

    看如下情況:

    

為什么 {} + [] = 0 ?  因為 javascript在運行時, 將 第一次{} 認為是空的代碼塊,所以就相當于 +[] = 0.  還有 {} +5 = 5, 同理。

總結:

1. 類型錯誤有可能會被類型轉(zhuǎn)換所隱藏。

2. “+”既可以表示字符串連接,又可以表示算術加,這取決于它的操作數(shù),如果有一個為字符串的,那么,就是字符串連接了。

3. 對象通過valueOf方法,把自己轉(zhuǎn)換成數(shù)字,通過toString方法,把自己轉(zhuǎn)換成字符串。

4.具有valueOf方法的對象,應該定義一個相應的toString方法,用來返回相等的數(shù)字的字符串形式。

5.檢測一些未定義的變量時,應該使用typeOf或者與undefined作比較,而不應該直接用真值運算。

總結

以上所述是小編給大家介紹的JavaScript中的一些隱式轉(zhuǎn)換和總結(推薦),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家的支持!

相關文章

  • 使用3D引擎threeJS實現(xiàn)星空粒子移動效果

    使用3D引擎threeJS實現(xiàn)星空粒子移動效果

    這篇文章主要為大家詳細介紹了使用3D引擎threeJS實現(xiàn)星空粒子移動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • TypeScript對于Duck類型和模塊命名空間應用

    TypeScript對于Duck類型和模塊命名空間應用

    這篇文章主要介紹了TypeScript對于Duck類型和模塊命名空間應用,Duck類型是一種動態(tài)類型和多態(tài)形式,在duck類型中,重點是對象的行為可以做什么,而不是對象所屬的類型
    2022-08-08
  • 在微信小程序中使用mqtt服務的方法

    在微信小程序中使用mqtt服務的方法

    這篇文章主要介紹了在微信小程序中使用mqtt服務的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • bootstrap flask登錄頁面編寫實例

    bootstrap flask登錄頁面編寫實例

    這篇文章主要為大家詳細介紹了bootstrap flask登錄頁面編寫實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • 繁簡字轉(zhuǎn)換功能

    繁簡字轉(zhuǎn)換功能

    繁簡字轉(zhuǎn)換功能...
    2006-07-07
  • 一文詳解如何檢測并解決JS代碼中的死循環(huán)

    一文詳解如何檢測并解決JS代碼中的死循環(huán)

    這篇文章主要想和大家來一起探討一下能否通過靜態(tài)分析的方式檢測出死循環(huán),如果不能,我們又應該如何在不借用其他線程的情況下,解決死循環(huán)卡住問題,感興趣的可以了解下
    2023-09-09
  • JavaScript中eval和with語句如何影響作用域鏈的深度探索

    JavaScript中eval和with語句如何影響作用域鏈的深度探索

    這篇文章主要為大家介紹了JavaScript中eval和with語句如何影響作用域鏈的深度探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • javascript特殊日歷控件分享

    javascript特殊日歷控件分享

    這篇文章主要為大家詳細介紹了javascript特殊日歷控件的使用方法,展示了javascript日歷控件實現(xiàn)效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-03-03
  • uniapp實現(xiàn)日期時間選擇器

    uniapp實現(xiàn)日期時間選擇器

    這篇文章主要為大家詳細介紹了uniapp實現(xiàn)日期時間選擇器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • js實現(xiàn)圖片在未加載完成前顯示加載中字樣

    js實現(xiàn)圖片在未加載完成前顯示加載中字樣

    首先判斷瀏覽器再判斷圖片是否加載完成,如果還未加載就顯示“加載中...”,思路及代碼如下
    2014-09-09

最新評論