undefined與null的區別

jopen 10年前發布 | 10K 次閱讀 語言

        大多數計算機語言,都有一個表示"無"的值,比如,C語言的 NULL,Java 語言的 null,Python 語言的 none,Ruby 語言的 nil。

        有點奇怪的是,JavaScript 語言居然有兩個表示"無"的值:undefined 和 null。這是為什么?

undefined與null的區別

        一、相似性

        在 JavaScript 中,將一個變量賦值為 undefined 或 null,老實說,幾乎沒區別。

var a = undefined;var a = null;

        上面代碼中,a變量分別被賦值為 undefined 和 null,這兩種寫法幾乎等價。

        undefined 和 null 在 if 語句中,都會被自動轉為 false,相等運算符甚至直接報告兩者相等。

if (!undefined) 
    console.log ('undefined is false');// undefined is false if (!null) 
    console.log ('null is false');// null is false  undefined == null // true

        上面代碼說明,兩者的行為是何等相似!

        既然 undefined 和 null 的含義與用法都差不多,為什么要同時設置兩個這樣的值,這不是無端增加 JavaScript 的復雜度,令初學者困擾嗎?Google 公司開發的 JavaScript 語言的替代品 Dart 語言,就明確規定只有 null,沒有 undefined!

        二、歷史原因

        最近,我在讀新書《Speaking JavaScript》時,意外發現了這個問題的答案!

        原來,這與 JavaScript 的歷史有關。1995 年 JavaScript 誕生時,最初像 Java 一樣,只設置了 null 作為表示"無"的值。

        根據C語言的傳統,null 被設計成可以自動轉為0。

Number (null)// 0 5 + null // 5

        但是,JavaScript 的設計者 Brendan Eich,覺得這樣做還不夠,有兩個原因。

        首先,null 像在 Java 里一樣,被當成一個對象。

typeof null // "object"

        但是,JavaScript 的數據類型分成原始類型(primitive)和合成類型(complex)兩大類,Brendan Eich 覺得表示"無"的值最好不是對象。

        其次,JavaScript 的最初版本沒有包括錯誤處理機制,發生數據類型不匹配時,往往是自動轉換類型或者默默地失敗。Brendan Eich 覺得,如果 null 自動轉為0,很不容易發現錯誤。

        因此,Brendan Eich 又設計了一個 undefined。

        三、最初設計

        JavaScript 的最初版本是這樣區分的:null 是一個表示"無"的對象,轉為數值時為0;undefined 是一個表示"無"的原始值,轉為數值時為 NaN。

Number (undefined)// NaN 5 + undefined// NaN

        四、目前的用法

        但是,上面這樣的區分,在實踐中很快就被證明不可行。目前,null 和 undefined 基本是同義的,只有一些細微的差別。

        null 表示"沒有對象",即該處不應該有值。典型用法是:

(1) 作為函數的參數,表示該函數的參數不是對象。

(2) 作為對象原型鏈的終點。

Object.getPrototypeOf (Object.prototype)// null

        undefined 表示"缺少值",就是此處應該有一個值,但是還沒有定義。典型用法是:

(1)變量被聲明了,但沒有賦值時,就等于 undefined。

(2) 調用函數時,應該提供的參數沒有提供,該參數等于 undefined。

(3)對象沒有賦值的屬性,該屬性的值為 undefined。

(4)函數沒有返回值時,默認返回 undefined。

var i;
i // undefined function f (x){console.log (x)}
f () // undefined var o = new Object ();
o.p // undefined var x = f ();
x // undefined

        (完)

                    <span id="shareA4" class="fl">                          </span> 

</div>

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!