首頁 web前端 js教程 詳解javascript中原始資料型別Null和Undefined_javascript技巧

詳解javascript中原始資料型別Null和Undefined_javascript技巧

May 16, 2016 pm 03:25 PM
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; // false
undefined == ""; // false
null == false; // false
undefined == false; // false
null == 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 属性不存在, 返回 undefined
var item = array[5]; // 数组中没有索引为5的项,返回 undefined
登入後複製

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

var value = (function(){})(); // 返回 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進行的介紹,希望對大家的學習有所幫助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

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

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

如何使用WebSocket和JavaScript實現線上語音辨識系統 如何使用WebSocket和JavaScript實現線上語音辨識系統 Dec 17, 2023 pm 02:54 PM

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術 WebSocket與JavaScript:實現即時監控系統的關鍵技術 Dec 17, 2023 pm 05:30 PM

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統 如何利用JavaScript和WebSocket實現即時線上點餐系統 Dec 17, 2023 pm 12:09 PM

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統 如何使用WebSocket和JavaScript實現線上預約系統 Dec 17, 2023 am 09:39 AM

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

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()

JavaScript與WebSocket:打造高效率的即時天氣預報系統 JavaScript與WebSocket:打造高效率的即時天氣預報系統 Dec 17, 2023 pm 05:13 PM

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

javascript如何使用insertBefore javascript如何使用insertBefore Nov 24, 2023 am 11:56 AM

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

See all articles