您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關javascript中null有什么用的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
javascript中null是JS提供的一種特殊值,表示缺少對象;在javascript中可以使用嚴格相等運算符來檢查null值,其檢查語句如“missingObject === null;”。
本文操作環境:windows7系統、javascript1.8.5版,DELL G3電腦。
javascript中null是什么?
JavaScript中關于null的一切
JavaScript有2種類型:基本類型(string, booleans number, symbol)和對象。
對象是復雜的數據結構,JS 中最簡單的對象是普通對象:一組鍵和關聯值:
let myObject = { name: '前端小智' }
但是在某些情況下無法創建對象。 在這種情況下,JS 提供一個特殊值null
—表示缺少對象。
let myObject = null
值 null 特指對象的值未設置,它是 JS 基本類型 之一,在布爾運算中被認為是falsy。
例如,函數greetObject()創建對象,但是在無法創建對象時也可以返回null:
function greetObject(who) { if (!who) { return null; } return { message: `Hello, ${who}!` }; } greetObject('Eric'); // => { message: 'Hello, Eric!' } greetObject(); // => null
但是,在不帶參數的情況下調用函數greetObject() 時,該函數返回null
。 返回nul
l是合理的,因為who
參數沒有值。
檢查null
值的好方法是使用嚴格相等運算符:
const missingObject = null; const existingObject = { message: 'Hello!' }; missingObject === null; // => true existingObject === null; // => false
missingObject === null
的結果為true
,因為missingObject
變量包含一個null
值。
如果變量包含非空值(例如對象),則表達式existObject === null
的計算結果為false
。
null
與false、0、''、undefined、NaN
都是虛值
。如果在條件語句中遇到虛值,那么 JS 將把虛值強制為false
。
Boolean(null); // => false if (null) { console.log('null is truthy') } else { console.log('null is falsy') }
type null
的結果是什么
typeof null; // => 'object'
為什么是'object',typoef null
為object是早期 JS 實現中的一個錯誤。
要使用typeof運算符
檢測null
值。 如前所述,使用嚴格等于運算符myVar === null
。
如果我們想使用typeof
運算符檢查變量是否是對象,還需要排除null
值:
function isObject(object) { return typeof object === 'object' && object !== null; } isObject({ prop: 'Value' }); // => true isObject(15); // => false isObject(null); // => false
null
經常會在我們認為該變量是對象的情況下意外出現。然后,如果從null中提取屬性,JS 會拋出一個錯誤。
所以說我么你想要從一個對象上取屬性的時候,要注意判斷這個對象可能是null
, 要不然的話可能會出錯。
【推薦學習:《javascript基礎教程》】
當無法構造對象時,我們通常的做法是返回null
,但是這種做法有缺點。在執行堆棧中出現null
時,剛必須進行檢查。
嘗試避免返回 null
的做法:
返回默認對象而不是null
拋出錯誤而不是返回null
undefined
是未初始化的變量或對象屬性的值null
和undefined
之間的主要區別是,null
表示丟失的對象,而undefined
表示未初始化的狀態。
提示:文章寫完后,目錄可以自動生成,如何生成可參考右邊的幫助文檔
感謝各位的閱讀!關于“javascript中null有什么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。