JavaScript:undefined And null區別
下班吃飯的時候,同事偶然問了一個問題:undefined和null到底有什麼區別?無法回答,回去查閱相關資料,算了有了一個瞭解,做相關的總結,在開始之前,請看如下代碼,算是拋出這個問題:
console.info(undefined == null); //trueconsole.info(undefined === null); //false
上述結果可以給我們一個這樣的理解: undefined和null兩個值相等,但是他們含義不同。具體兩者有什麼區別,先理解下undefined和null在做分析。
undefined
undefined類型只有一個值,即特殊的undefined。在使用var聲明變數但未對其加以初始化,這個變數的值就是undefined。例如:
//1、聲明變數,未指定值var var1;console.info(typeof varl); //undefined//2、指定值為undefinedvar var2 = undefined;console.info(typeof var2); //undefined
上面兩種寫法是等價的,未經初始化的值預設就會取得undefined值。
Tips:一般而言不需要顯示的把一個變數設定為undefined,undefined的主要目的在於比較,ECMA第三版引入這個值正是為了區分Null 物件指標null和未經初始化的變數
既然談到了null,這裡在多補充一點,對為初始化的變數執行typeof返回undefined值,對為聲明的變數執行typeof也會返回undefined值,如下例子:
var var3;console.info(typeof var3); //undefinedconsole.info(typeof var4); //undefined
這個結果有邏輯上的合理性,雖然null和undefined在技術角度上有本質區別,但是實際中不可能對兩種變數進行操作。在這種情況下如果我們習慣聲明變數就進行初始化的時候,當typeof操作符返回“undefined”值時,我們就知道有變數尚未被聲明,而不是尚未初始化。
null
null類型也是只有一個值null,從邏輯角度來看,null值表示一個Null 物件指標,不信?看如下代碼就知道了:
var var5 = null;console.info(typeof var5); //object
所以在變數是用於儲存對象時,最後將之初始化為null,可以很方便的知道變數是否儲存了一個對象的引用。
區別
分別的瞭解了這兩種類型,到這裡似乎有所理解,但又不具體。回到最初拋出的問題,在ECMAScript的原始類型中,是有undefined和null類型的,這兩種類型分別對應了屬於自己的唯一值undefined和null。undefined實際上是從null派生而來,這就可以解釋undefined==null為true了。
就undefined===null為false分兩個方面來理解:
記憶體
很顯然,他們的地址分配不一樣,我想著對於有後端基礎的同學來說很容易理解,具體如:
用途
儘管undefined==null為true,但是他們的用途是不一樣的。就像前面所述,無論什麼情況都沒有必要將一個變數值顯示的指定為undefined,預設值為undefined,但是預設的規則對null卻不適用。因為null表示沒有指向對象的引用。
總的來說,undefined派生於null,他們是“=="的,另一層面上undefined表示沒有賦值的基礎資料型別 (Elementary Data Type),null表示沒有賦值的引用資料類型,他們不能“===”。