首頁 web前端 js教程 探索JavaScript中Null和Undefined的深淵

探索JavaScript中Null和Undefined的深淵

Dec 16, 2016 am 10:15 AM

當討論Javascript中Null和Undefined的深淵

當討論Javascript中的原始資料類型時,大多數人都知道的基本知識,從String,Number到Boolean。這些原始類型相當簡單,行為符合常識。但是,本文將更聚焦在獨特的原始資料類型Null和Undefined,是什麼讓他們如此相似,卻又似是而非。

理解Null和Undefined

在JavaScript中,null是字面量同時也是語言中的關鍵字,用來表示無法辨識的物件值。換句話說,這用來表示「無值(no value)」。雖然相似,undefined實際上代表了不存在的值(non-existence of a value)。都是完全不可變的,沒有屬性和方法,也不能給其屬性賦值。事實上,試圖存取或定義屬性將會引發一個類型錯誤(TypeError)。正如他們的名字暗示的那樣,他們是完全無效的值。

沒有值代表的布林值是false,這表示他們在條件上下文中會被計算為false,如if語句。使用相等運算子(= =)比較這兩個值和其他false值,他們並不等於除了自己:

null == 0; // falseundefined == ""; // falsenull == false; // falseundefined == false; // falsenull == undefined; // true

儘管如此,和其他相似之處,但null和undefined並不是等價的。每個作為其獨特的類型的唯一成員,undefined是Undefined類型和null是Null類型。使用全等運算子(===)比較這兩個值,這要求類型和值都相等,下面證明這一點:

undefined === null; // false
這是一個重要的區別,服務於不同的目的和理由。區分這兩個值,你可以認為undefined代表一個意想不到的沒有值而null作為預期沒有值的代表。

產生Undefined

有許多的方法產生一個undefined值的程式碼。它通常會遇到當試圖存取不存在的值時。在這種情況下,在JavaScript這種動態的弱型別語言中,只會預設回傳一個undefined值,而不是上升為一個錯誤。任何宣告變數時沒有提供一個初始值,都會有一個為undefined的預設值:var foo; // 預設值為undefined

當試圖存取一個不存在的物件屬性或陣列項目時,傳回一個undefined值:

var array = [1, 2, 3];var foo = array.foo; // foo 屬性不存在, 傳回undefinedvar item = array[5]; // 陣列中沒有索引為5的項,傳回undefined

如果省略了函數的返回語句,返回undefined:

var value = (function(){})(); // 傳回undefined

函數呼叫時未提供的值結果將為undefined參數值:


函數呼叫時未提供的值結果將為undefined參數值:

(function(undefined){    // 參數是undefined})();


void運算子也可以傳回一個undefined值。像Underscore的函式庫使用它作為一個防禦式的型別檢查,因為它是不可變的,可以在任何上下文依賴返回undefined:

function isUndefined(obj){    return obj === void 0;}


,undefined是一個預先定義的全域變數(不像null關鍵字)初始化為undefined值:

'undefined' in window; // true

ECMAScript 5中,這個變數是唯讀的,以前並非如此。

Null的用例

null的用例是使他與眾不同的主要方面,因為不像undefined,null被認為更有用。這正是為什麼typeof運算子作用於null值時傳回「object」。最初的理由是,現在仍然是,通常用作一個空引用一個空物件的預期,就像一個佔位符。 typeof的這種行為已經被確認為一個錯誤,雖然提出了修正,出於後相容的目的,這一點已經保持不變。這就是為什麼JavaScript環境從來沒有設定一個值為null;它必須以程式設計方式完成。如同文檔MDN所說:在api中,null是經常檢索物件的地方可以預期,但沒有相關的物件。這適用於DOM,它是獨立於語言的,不屬於ECMAScript規範的範圍。因為它是一個外部API,試圖取得一個不存在的元素傳回一個null值,而不是undefined。一般來說,如果你需要給一個變數或屬性指定一個不變值,將它傳遞給一個函數,或者從一個函數返回null,null幾乎總是最好的選擇。簡而言之,JavaScript使用undefined並且程式設計師應該使用null。 null的另一個可行的用例,也被認為是良好的實踐是一個明確指定變數為無效(object= null)當一個引用不再是必需的。透過分配null值,有效地清除引用,並假設物件沒有引用其他程式碼,指定垃圾收集,確保回收記憶體。 🎜🎜深入挖掘🎜

使null和undefined像黑洞的不只是他們的行為,而是在他們在JavaScript環境的內部的處理方式。他們似乎通常並不具有同樣的關聯特徵與其他原生或內建物件。在ES5中,Object.PRototype.toString方法,已經成為實際的類型檢查標準,這在null和undefined中被證明是一致的:Object.prototype.toString.call(null); // [object Null]Object. prototype.toString.call(undefined); // [object Undefined]

然而,Object.prototype.toString方法其實並不是檢索null的內部[[Class]]屬性或undefined的公開建構子。根據文檔,以下步驟發生在被調用過程中:

如果值是undefined,則返回「[object Undefined]」。

如果這個值為null,則回傳「[object Null]」。

讓O作為呼叫ToObject同時傳遞this值作為參數的結果值。

讓class是O的內部屬性[[Class]]的值。

傳回的結果連接三個字串“[object ”,class,和“]”的結果的字串值。

該方法執行一個簡單的字串回傳值,如果它偵測到null或undefined和其他物件統一的功能。在整個規範中這是很常見的,因為當遇到null和undefined值時大多數方法包含一個簡單的捕捉並傳回。事實上,沒有跡象表明他們包含與任何原生物件相關聯的內部屬性。就好像他們不是對象。我很想知道如果一個JavaScript的原生環境內部實際存在的明確方案會怎麼樣?也許有人更熟悉一個可以參與的實現。

結論

無論這些原生物件多麼不尋常,理解null和undefined之間的差異,和他們在JavaScript的語言基礎中截然不同的角色。它可能不能使你的應用程式有所突破,但是一般來說,它僅被證明在開發和調試中長期有益。

 以上就是探索JavaScript中Null和Undefined的深淵的內容,更多相關文章請關注PHP中文網(www.php.cn)! 


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

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP Notice: Undefined property: 的解決方法 PHP Notice: Undefined property: 的解決方法 Jun 22, 2023 pm 02:48 PM

在使用PHP編寫程式碼時,我們可能會遇到「Notice:Undefinedproperty」這個錯誤提示。這個錯誤提示意味著我們正在存取一個未定義的屬性,通常是因為該屬性在程式碼中尚未被初始化。那麼,該如何解決這個問題呢?以下是幾種可能的解決方法:初始化屬性這是解決問題的最簡單方法。在程式碼中明確地初始化屬性,可以確保它在使用前已經被定義。例如:class

Vue中的TypeError: Cannot read property '$XXX' of undefined,該如何處理? Vue中的TypeError: Cannot read property '$XXX' of undefined,該如何處理? Nov 25, 2023 pm 12:14 PM

如果你在使用Vue.js進行開發時,經常遇到「TypeError:Cannotreadproperty'$XXX'ofundefined」的錯誤提示,那麼該如何處理呢?本文將介紹這個錯誤的原因以及如何解決。問題的原因在使用Vue.js的時候,我們常常會用this來呼叫Vue元件的方法,例如:exportdefault{data()

c語言中null和NULL的差別是什麼 c語言中null和NULL的差別是什麼 Sep 22, 2023 am 11:48 AM

c語言中null和NULL的差異是:null是C語言中的一個宏定義,通常用來表示一個空指針,可以用來初始化指針變量,或是在條件語句中判斷指針是否為空;NULL是C語言中的一個預先定義常數,通常用來表示一個空值,用來表示一個空的指標、空的指標數組或是空的結構體指標。

undefined和null是什麼意思 undefined和null是什麼意思 Nov 20, 2023 pm 02:39 PM

在JavaScript 中,undefined和null都代表著「無」的概念:1、undefined 表示一個未初始化的變數或一個不存在的屬性,當宣告了一個變數但沒有對其賦值時,這個變數的值就是undefined ,當存取物件中不存在的屬性時,傳回的值也是undefined;2、null表示一個空的物件引用,在某些情況下,可以將物件的引用設為null,以便釋放其佔用的記憶體。

undefined是什麼 undefined是什麼 Jul 31, 2023 pm 02:28 PM

undefined是代表一個值或變數不存在或未定義的狀態。它可以作為預設值來判斷一個變數是否已經被賦值,也可以用來設定預設參數值。儘管在不同的程式語言中,undefined可能具有不同的意義和用法,但理解undefined的概念可以幫助我們更好地理解和編寫程式。

如何解決 golang 中的 'undefined: path.Join” 錯誤? 如何解決 golang 中的 'undefined: path.Join” 錯誤? Jun 24, 2023 pm 01:12 PM

在Go語言中,path套件是處理檔案路徑的重要工具之一。其中path.Join()函數可以將多個路徑組合成一個完整的路徑。但是,有時你會遇到「undefined:path.Join」的錯誤訊息,該怎麼辦呢?以下是幾個常見的解決方法:檢查import語句首先,你需要確認自己已經正確import了path套件。在Go語言中,匯入包時可

什麼時候用null和undefined 什麼時候用null和undefined Nov 13, 2023 pm 02:11 PM

null和undefined都表示缺少值或未定義的狀態,根據使用場景的不同,選擇使用null或undefined有以下一些指導原則:1、當需要明確指示一個變數為空或無效時,可以使用null;2、當一個變數已經宣告但尚未賦值時,會被預設為undefined;3、當需要檢查一個變數是否為空或未定義時,使用嚴格相等運算子「===」來判斷變數是否為null或undefined 。

null和undefined有什麼不同 null和undefined有什麼不同 Nov 08, 2023 pm 04:43 PM

null和undefined的差異在:1、語意意義;2、使用場景;3、與其它值的比較;4、與全域變數的關係;5、與函數參數的關係;6、可空性檢定;7、性能考慮;8、在JSON序列化中的表現;9、與類型的關係。詳細介紹:1、語意意義,null通常表示知道這個變數不會擁有任何有效的物件值,而undefined則通常表示變數未被賦值,或物件沒有此屬性;2、使用場景等等。

See all articles