日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
JavaScript中關(guān)于null的一切

本文已經(jīng)作者@Dmitri Pavluti授權(quán)翻譯

成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供永昌企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站制作、網(wǎng)站設(shè)計(jì)html5、小程序制作等業(yè)務(wù)。10年已為永昌眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進(jìn)行中。

JavaScript有2種類型:基本類型(string, booleans number, symbol)和對(duì)象。

對(duì)象是復(fù)雜的數(shù)據(jù)結(jié)構(gòu),JS 中最簡(jiǎn)單的對(duì)象是普通對(duì)象:一組鍵和關(guān)聯(lián)值:

 
 
 
 
  1. let myObject = { 
  2.   name: '前端小智' 

但是在某些情況下無(wú)法創(chuàng)建對(duì)象。 在這種情況下,JS 提供一個(gè)特殊值null —表示缺少對(duì)象。

 
 
 
 
  1. 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 基本類型 之一,在布爾運(yùn)算中被認(rèn)為是falsy。

例如,函數(shù)greetObject()創(chuàng)建對(duì)象,但是在無(wú)法創(chuàng)建對(duì)象時(shí)也可以返回null:

 
 
 
 
  1. function greetObject(who) { 
  2.   if (!who) { 
  3.     return null; 
  4.   } 
  5.   return { message: `Hello, ${who}!` }; 
  6.  
  7. greetObject('Eric'); // => { message: 'Hello, Eric!' } 
  8. greetObject();       // => null 

但是,在不帶參數(shù)的情況下調(diào)用函數(shù)greetObject()時(shí),該函數(shù)返回null。 返回null是合理的,因?yàn)閣ho參數(shù)沒(méi)有值。

2. 如何檢查null

檢查null值的好方法是使用嚴(yán)格相等運(yùn)算符:

 
 
 
 
  1. const missingObject = null; 
  2. const existingObject = { message: 'Hello!' }; 
  3.  
  4. missingObject  === null; // => true 
  5. 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。

 
 
 
 
  1. Boolean(null); // => false 
  2.  
  3. if (null) { 
  4.   console.log('null is truthy') 
  5. } else { 
  6.   console.log('null is falsy') 

2.2 typeof null

typeof value運(yùn)算符確定值的類型。 例如,typeof 15是'number',typeof {prop:'Value'}的計(jì)算結(jié)果是'object'。

有趣的是,type null的結(jié)果是什么

 
 
 
 
  1. 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值:

 
 
 
 
  1. function isObject(object) { 
  2.   return typeof object === 'object' && object !== null; 
  3.  
  4. isObject({ prop: 'Value' }); // => true 
  5. isObject(15);                // => false 
  6. 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屬性:

 
 
 
 
  1. let who = ''; 
  2.  
  3. greetObject(who).message;  
  4. // throws "TypeError: greetObject() is null" 

因?yàn)閣ho變量是一個(gè)空字符串,所以該函數(shù)返回null。 從null訪問(wèn)message屬性時(shí),將引發(fā)TypeError錯(cuò)誤。

可以通過(guò)使用帶有空值合并的可選鏈接來(lái)處理null:

 
 
 
 
  1. let who = '' 
  2.  
  3. greetObject(who)?.message ?? 'Hello, Stranger!' 
  4. // => '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:

 
 
 
 
  1. function greetObject(who) { 
  2.   if (!who) { 
  3.     who = 'Stranger'; 
  4.   } 
  5.   return { message: `Hello, ${who}!` }; 
  6.  
  7. greetObject('Eric'); // => { message: 'Hello, Eric!' } 
  8. greetObject();       // => { message: 'Hello, Stranger!' } 

或者拋出一個(gè)錯(cuò)誤:

 
 
 
 
  1. function greetObject(who) { 
  2.   if (!who) { 
  3.     throw new Error('"who" argument is missing'); 
  4.   } 
  5.   return { message: `Hello, ${who}!` }; 
  6.  
  7. greetObject('Eric'); // => { message: 'Hello, Eric!' } 
  8. greetObject();       // => throws an error 

這兩種做法可以避免使用 null。

5. null vs undefined

undefined是未初始化的變量或?qū)ο髮傩缘闹?,undefined是未初始化的變量或?qū)ο髮傩缘闹怠?/p>

 
 
 
 
  1. let myVariable; 
  2.  
  3. myVariable; // => undefined 

null和undefined之間的主要區(qū)別是,null表示丟失的對(duì)象,而undefined表示未初始化的狀態(tài)。

嚴(yán)格的相等運(yùn)算符===區(qū)分null和undefined :

 
 
 
 
  1. null === undefined // => false 

而雙等運(yùn)算符==則認(rèn)為null和undefined 相等

 
 
 
 
  1. null == undefined // => true 

我使用雙等相等運(yùn)算符檢查變量是否為null 或undefined:

 
 
 
 
  1. function isEmpty(value) { 
  2.   return value == null; 
  3.  
  4. isEmpty(42);                // => false 
  5. isEmpty({ prop: 'Value' }); // => false 
  6. isEmpty(null);              // => true 
  7. isEmpty(undefined);         // => true 

6. 總結(jié)

null是JavaScript中的一個(gè)特殊值,表示丟失的對(duì)象,嚴(yán)格相等運(yùn)算符確定變量是否為空:variable === null。

typoef運(yùn)算符對(duì)于確定變量的類型(number, string, boolean)很有用。 但是,如果為null,則typeof會(huì)產(chǎn)生誤導(dǎo):typeof null的值為'object'。

null和undefined在某種程度上是等價(jià)的,但null表示缺少對(duì)象,而undefined未初始化狀態(tài)。

作者:Dmitri Pavluti 譯者:前端小智 來(lái)源:dmitripavlutin原文:https://dmitripavlutin.com/javascript-null/#comments

本文轉(zhuǎn)載自微信公眾號(hào)「 大遷世界」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系 大遷世界公眾號(hào)。


當(dāng)前名稱:JavaScript中關(guān)于null的一切
路徑分享:http://www.5511xx.com/article/cdesjij.html