您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)JavaScript中null的介紹以及用法是怎樣的,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話(huà)不多說(shuō),跟著小編一起來(lái)看看吧。
JavaScript有2種類(lèi)型:基本類(lèi)型(string, booleans number, symbol)和對(duì)象。
對(duì)象是復(fù)雜的數(shù)據(jù)結(jié)構(gòu),JS 中最簡(jiǎn)單的對(duì)象是普通對(duì)象:一組鍵和關(guān)聯(lián)值:
let myObject = { name: '前端小智' }
但是在某些情況下無(wú)法創(chuàng)建對(duì)象。 在這種情況下,JS 提供一個(gè)特殊值null —表示缺少對(duì)象。
let myObject = null
這里我們將了解到有關(guān)JavaScript中null的所有知識(shí):它的含義,如何檢測(cè)它,null與undefined之間的區(qū)別以及為什么使用null造成代碼維護(hù)困難。
1. null的概念
JS 規(guī)范說(shuō)明了有關(guān)null的信息:
值 null 特指對(duì)象的值未設(shè)置,它是 JS 基本類(lèi)型 之一,在布爾運(yùn)算中被認(rèn)為是falsy。
例如,函數(shù)greetObject()創(chuàng)建對(duì)象,但是在無(wú)法創(chuàng)建對(duì)象時(shí)也可以返回null:
function greetObject(who) { if (!who) { return null; } return { message: `Hello, ${who}!` }; } greetObject('Eric'); // => { message: 'Hello, Eric!' } greetObject(); // => null
但是,在不帶參數(shù)的情況下調(diào)用函數(shù)greetObject()時(shí),該函數(shù)返回null。 返回null是合理的,因?yàn)閣ho參數(shù)沒(méi)有值。
2. 如何檢查null
檢查null值的好方法是使用嚴(yán)格相等運(yùn)算符:
const missingObject = null; const existingObject = { message: 'Hello!' }; missingObject === null; // => true existingObject === null; // => false
missingObject === null的結(jié)果為true,因?yàn)閙issingObject變量包含一個(gè)null 值。
如果變量包含非空值(例如對(duì)象),則表達(dá)式existObject === null的計(jì)算結(jié)果為false。
2.1 null 是虛值
null與false、0、''、undefined、NaN都是虛值。如果在條件語(yǔ)句中遇到虛值,那么 JS 將把虛值強(qiáng)制為false。
Boolean(null); // => false if (null) { console.log('null is truthy') } else { console.log('null is falsy') }
2.2 typeof null
typeof value運(yùn)算符確定值的類(lèi)型。 例如,typeof 15是'number',typeof {prop:'Value'}的計(jì)算結(jié)果是'object'。
有趣的是,type null的結(jié)果是什么
typeof null; // => 'object'
為什么是'object',typoef null為object是早期 JS 實(shí)現(xiàn)中的一個(gè)錯(cuò)誤。
要使用typeof運(yùn)算符檢測(cè)null值。 如前所述,使用嚴(yán)格等于運(yùn)算符myVar === null。
如果我們想使用typeof運(yùn)算符檢查變量是否是對(duì)象,還需要排除null值:
function isObject(object) { return typeof object === 'object' && object !== null; } isObject({ prop: 'Value' }); // => true isObject(15); // => false isObject(null); // => false
3. null 的陷阱
null經(jīng)常會(huì)在我們認(rèn)為該變量是對(duì)象的情況下意外出現(xiàn)。然后,如果從null中提取屬性,JS 會(huì)拋出一個(gè)錯(cuò)誤。
再次使用greetObject()函數(shù),并嘗試從返回的對(duì)象訪問(wèn)message屬性:
let who = ''; greetObject(who).message; // throws "TypeError: greetObject() is null"
因?yàn)閣ho變量是一個(gè)空字符串,所以該函數(shù)返回null。 從null訪問(wèn)message屬性時(shí),將引發(fā)TypeError錯(cuò)誤。
可以通過(guò)使用帶有空值合并的可選鏈接來(lái)處理null:
let who = '' greetObject(who)?.message ?? 'Hello, Stranger!' // => 'Hello, Stranger!'
4. null 的替代方法
當(dāng)無(wú)法構(gòu)造對(duì)象時(shí),我們通常的做法是返回null,但是這種做法有缺點(diǎn)。在執(zhí)行堆棧中出現(xiàn)null時(shí),剛必須進(jìn)行檢查。
嘗試避免返回 null 的做法:
返回默認(rèn)對(duì)象而不是null
拋出錯(cuò)誤而不是返回null
回到開(kāi)始返回greeting對(duì)象的greetObject()函數(shù)。缺少參數(shù)時(shí),可以返回一個(gè)默認(rèn)對(duì)象,而不是返回null:
function greetObject(who) { if (!who) { who = 'Stranger'; } return { message: `Hello, ${who}!` }; } greetObject('Eric'); // => { message: 'Hello, Eric!' } greetObject(); // => { message: 'Hello, Stranger!' }
或者拋出一個(gè)錯(cuò)誤:
function greetObject(who) { if (!who) { throw new Error('"who" argument is missing'); } return { message: `Hello, ${who}!` }; } greetObject('Eric'); // => { message: 'Hello, Eric!' } greetObject(); // => throws an error
這兩種做法可以避免使用 null。
5. null vs undefined
undefined是未初始化的變量或?qū)ο髮傩缘闹?,undefined是未初始化的變量或?qū)ο髮傩缘闹怠?/p>
let myVariable; myVariable; // => undefined
null和undefined之間的主要區(qū)別是,null表示丟失的對(duì)象,而undefined表示未初始化的狀態(tài)。
嚴(yán)格的相等運(yùn)算符===區(qū)分null和undefined :
null === undefined // => false
而雙等運(yùn)算符==則認(rèn)為null和undefined 相等
null == undefined // => true
我使用雙等相等運(yùn)算符檢查變量是否為null 或undefined:
function isEmpty(value) { return value == null; } isEmpty(42); // => false isEmpty({ prop: 'Value' }); // => false isEmpty(null); // => true isEmpty(undefined); // => true
6. 總結(jié)
null是JavaScript中的一個(gè)特殊值,表示丟失的對(duì)象,嚴(yán)格相等運(yùn)算符確定變量是否為空:variable === null。
typoef運(yùn)算符對(duì)于確定變量的類(lèi)型(number, string, boolean)很有用。 但是,如果為null,則typeof會(huì)產(chǎn)生誤導(dǎo):typeof null的值為'object'。
null和undefined在某種程度上是等價(jià)的,但null表示缺少對(duì)象,而undefined未初始化狀態(tài)。
以上就是JavaScript中null的介紹以及用法是怎樣的,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。