首頁  >  文章  >  web前端  >  Javascript中雙等號隱性轉換機制分析

Javascript中雙等號隱性轉換機制分析

小云云
小云云原創
2018-01-20 11:26:231246瀏覽

本文主要和大家詳細介紹了javascript中雙等號(==)隱性轉換機制,非常不錯,具有參考借鑒價值,需要的朋友參考下吧,希望能幫助到大家。

在Javascript中判斷相等關係有雙等號(==)和三等號(===)兩種。其中雙等號(==)是值相等,而三等號(===)是嚴格相等(值及類型是否完全相等)。

因此有幾個常識知識:

1、對於string,number等基礎類型,==和===是有區別的

  1)不同類型間比較,==之比較「轉換成相同型別後的值」看「值」是否相等,===如果型別不同,其結果就是不等

  2)同型別比較,直接進行「值」比較,兩者結果一樣

2、對於Array,Object等高階類型,==和===是沒有區別的

  進行「指標位址」比較

#3、基礎類型與進階類型,==和===是有區別的

  1)對於==,將高階轉換為基礎類型,進行「值」比較

  2 )因為型別不同,===結果為false

換句話說,雙等號(==)在運算的時候會進行型別轉換,而三等號(===)則不會。

如:

alert('55' == 55); //true
alert('55' === 55); //false

Javascript語言中五大基本資料型別(原始值,也叫簡單資料型別):即 Undefined、Null、Boolean、Number 與 String 型。由於這些原始類型佔據的空間是固定的,所以可將他們儲存在較小的記憶體區域 - 堆疊中。這樣儲存方便迅速查尋變數的值;

Javascript中使用雙等號(==)判斷相等的隱性轉換機制:

#1,如果兩邊都是簡單型別:

  1,1,兩邊都是簡單類型,且類型相同,則直接進行比較。

console.log(1==1); //true
console.log("1"=="1"); //true
console.log(false==false); //true
console.log(null==null); //true
console.log(undefined==undefined); //true

  1.2,兩邊都是簡單類型,類型不同,則先轉換為數字比較(其中Boolean只有兩個值:true==1,false==0;null與undefined相等;字串數字等於數字值,空字串""==0;)

console.log(1==true); //true
console.log(0==false); //true
console.log(1=="1"); //true
console.log(0==""); //true
console.log(0==null); //false
console.log(0==undefined); //false
console.log(null==undefined); //true

2,如果一邊是簡單類型,另一邊是引用類型(高級類型),則高級類型隱式轉換成簡單類型再比較。

console.log(Object==Object); //true
console.log(Object=={}); //false
console.log(0=={}); //false
console.log(0==[]); //true
console.log(Array==Array); //true
console.log(Object==Array); //false

3,如果兩邊都是引用型別(進階型別),則會進行「指標位址」比較。

重點-toString()和valueOf()

很多人看到這兩個方法的第一個感覺就是,toString()方法將一個物件轉換為字串,valueOf方法將一個物件轉化為數值。

這種想法很片面,我們透過以下兩個例子來看看:

var obj={
  name:"熊仔其人",
  getName:function(){ return $(this).name; }
};
console.log(obj.toString()); //[object Object]

定義一個obj對象,呼叫它的toString方法,傳回值是[object Object],發現並未像我們想像的一樣傳回值其內容的字串表示。

var arr=[1,2,3];
console.log(arr.valueOf()); //(3) [1, 2, 3]

定義一個陣列arr,呼叫它的valueOf方法,傳回值是[1, 2, 3],發現也並未像我們想像的一樣傳回數值類型的表示。

其實真正的理解是這樣的:呼叫物件的toString()方法可以將物件轉換為字串,但是如果要轉換成字串不一定是呼叫toString方法。

我們再看看下面的程式碼。

var obj= { };   
obj.valueOf=function(){ return 1; }
obj.toString=function(){ return 2; }
console.log(obj==1);  //true
var obj2= { };   
obj2.valueOf=function(){ return 2; }
obj2.toString=function(){ return 1; }
console.log(obj2==1);  //false                                      
var obj3={ };
obj3.valueOf=function(){ return []; }
obj3.toString=function(){ return 1; }
console.log(obj3==1);  //true

上述程式碼中我們定義了一個物件obj,obj2,定義了valueOf和toString方法的回傳值,透過與1比較相等,發現其優先呼叫了valueOf方法。

接著定義了一個物件obj3,定義了valueOf和toString方法的回傳值,透過與1比較相等,發現其呼叫的是toString方法。

然後我們看下面一段程式碼:

var obj= { };   
obj.valueOf=function(){ return 'a'; }
obj.toString=function(){ return 2; }
console.log(obj=='a');  //true
var obj2= { };   
obj2.valueOf=function(){ return 'b'; }
obj2.toString=function(){ return 'a'; }
console.log(obj2=='a');  //false

上述程式碼2中定義一個物件obj,透過與字串'a'比較發現其呼叫的是valueOf方法。

然後物件obj2與'a'的比較回傳false,發現其並未呼叫toString方法。

由此我們可以得出結論:

物件轉換為簡單類型時會優先呼叫valueOf方法,如果可以與簡單值進行比較則會直接比較,此時不再呼叫toString方法。如果呼叫valueOf方法後無法與簡單值進行比較,則會再呼叫toString方法,最終得到比對的結果。

但是要注意的一點是Date物件不符合上述的規則,Date物件的toString和valueOf方法都是重新定義過的,預設會呼叫toString方法。

PS:js的雙等號隱式轉換規則

使用雙等號進行比較的時候,當兩個運算元類型不一樣時,雙等號會進行一個隱式轉換,轉換成相同類型再比較,以下是轉換規則,在紅寶書P51頁都能查到。 (自己總是忘記,還是覺得好記性不如爛筆頭,寫一寫總是影響深刻)

1、有一個操作數為布爾值,將布爾值轉換成數值再進行比較,false為0,true為1.

2、一個為字串,另一個為數字。將字串轉換成數值再進行比較。

3、一個運算符為對象,另一個不是對象,先利用 valueOf() 得到對象值得類型,再依照其他規則比較。

相關推薦:

javascript中if和switch,==和===區別和聯繫實例詳解

PHP的 == 運算子字串比較用法及其副作用實例詳解

#Oracle資料型別的隱性轉換

以上是Javascript中雙等號隱性轉換機制分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn