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

當討論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
Python vs. JavaScript:學習曲線和易用性Python vs. JavaScript:學習曲線和易用性Apr 16, 2025 am 12:12 AM

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

Python vs. JavaScript:社區,圖書館和資源Python vs. JavaScript:社區,圖書館和資源Apr 15, 2025 am 12:16 AM

Python和JavaScript在社區、庫和資源方面的對比各有優劣。 1)Python社區友好,適合初學者,但前端開發資源不如JavaScript豐富。 2)Python在數據科學和機器學習庫方面強大,JavaScript則在前端開發庫和框架上更勝一籌。 3)兩者的學習資源都豐富,但Python適合從官方文檔開始,JavaScript則以MDNWebDocs為佳。選擇應基於項目需求和個人興趣。

從C/C到JavaScript:所有工作方式從C/C到JavaScript:所有工作方式Apr 14, 2025 am 12:05 AM

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

JavaScript引擎:比較實施JavaScript引擎:比較實施Apr 13, 2025 am 12:05 AM

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

超越瀏覽器:現實世界中的JavaScript超越瀏覽器:現實世界中的JavaScriptApr 12, 2025 am 12:06 AM

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

使用Next.js(後端集成)構建多租戶SaaS應用程序使用Next.js(後端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:23 AM

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

如何使用Next.js(前端集成)構建多租戶SaaS應用程序如何使用Next.js(前端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:22 AM

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript:探索網絡語言的多功能性JavaScript:探索網絡語言的多功能性Apr 11, 2025 am 12:01 AM

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

See all articles

熱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.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具