成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript中關(guān)于null的一切

開發(fā) 前端
JavaScript有2種類型:基本類型(string, booleans number, symbol)和對象。

 [[346109]]

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

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

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

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

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

  1. let myObject = null 

在本文中,我們將了解到有關(guān)JavaScript中null的所有知識:它的含義,如何檢測它,null與undefined之間的區(qū)別以及為什么使用null造成代碼維護困難。

1. null的概念

JS 規(guī)范說明了有關(guān)null的信息:

值 null 特指對象的值未設(shè)置,它是 JS 基本類型 之一,在布爾運算中被認為是falsy。

例如,函數(shù)greetObject()創(chuàng)建對象,但是在無法創(chuàng)建對象時也可以返回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ù)返回null。 返回null是合理的,因為who參數(shù)沒有值。

2. 如何檢查null

檢查null值的好方法是使用嚴格相等運算符:

  1. const missingObject = null
  2. const existingObject = { message: 'Hello!' }; 
  3.  
  4. missingObject  === null; // => true 
  5. existingObject === null; // => false 

missingObject === null的結(jié)果為true,因為missingObject變量包含一個null 值。

如果變量包含非空值(例如對象),則表達式existObject === null的計算結(jié)果為false。

2.1 null 是虛值

null與false、0、''、undefined、NaN都是虛值。如果在條件語句中遇到虛值,那么 JS 將把虛值強制為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運算符確定值的類型。 例如,typeof 15是'number',typeof {prop:'Value'}的計算結(jié)果是'object'。

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

  1. typeof null; // => 'object' 

為什么是'object',typoef null為object是早期 JS 實現(xiàn)中的一個錯誤。

要使用typeof運算符檢測null值。 如前所述,使用嚴格等于運算符myVar === null。

如果我們想使用typeof運算符檢查變量是否是對象,還需要排除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)常會在我們認為該變量是對象的情況下意外出現(xiàn)。然后,如果從null中提取屬性,JS 會拋出一個錯誤。

再次使用greetObject()函數(shù),并嘗試從返回的對象訪問message屬性:

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

因為who變量是一個空字符串,所以該函數(shù)返回null。 從null訪問message屬性時,將引發(fā)TypeError錯誤。

可以通過使用帶有空值合并的可選鏈接來處理null:

  1. let who = '' 
  2.  
  3. greetObject(who)?.message ?? 'Hello, Stranger!' 
  4. // => 'Hello, Stranger!' 

4. null 的替代方法

當(dāng)無法構(gòu)造對象時,我們通常的做法是返回null,但是這種做法有缺點。在執(zhí)行堆棧中出現(xiàn)null時,剛必須進行檢查。

嘗試避免返回 null 的做法:

  • 返回默認對象而不是null
  • 拋出錯誤而不是返回null

回到開始返回greeting對象的greetObject()函數(shù)。缺少參數(shù)時,可以返回一個默認對象,而不是返回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!' } 

或者拋出一個錯誤:

  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ū)ο髮傩缘闹担瑄ndefined是未初始化的變量或?qū)ο髮傩缘闹怠?/p>

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

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

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

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

而雙等運算符==則認為null和undefined 相等

  1. null == undefined // => true 

我使用雙等相等運算符檢查變量是否為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中的一個特殊值,表示丟失的對象,嚴格相等運算符確定變量是否為空:variable === null。

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

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

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

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

 

責(zé)任編輯:武曉燕 來源: 大遷世界
相關(guān)推薦

2020-09-11 10:55:10

useState組件前端

2018-11-23 11:17:24

負載均衡分布式系統(tǒng)架構(gòu)

2021-02-19 23:08:27

軟件測試軟件開發(fā)

2021-02-28 09:47:54

軟件架構(gòu)軟件開發(fā)軟件設(shè)計

2021-05-28 07:12:59

Python閉包函數(shù)

2022-08-21 17:35:31

原子多線程

2023-04-20 10:15:57

React組件Render

2022-04-02 09:38:00

CSS3flex布局方式

2023-02-10 08:44:05

KafkaLinkedIn模式

2018-01-05 14:23:36

計算機負載均衡存儲

2021-08-09 14:40:02

物聯(lián)網(wǎng)IOT智能家居

2023-07-10 10:36:17

人工智能AI

2022-08-17 06:25:19

偽共享多線程

2018-01-17 09:15:52

負載均衡算法

2023-04-12 14:04:48

光纖網(wǎng)絡(luò)

2024-08-26 11:59:35

2015-06-24 09:54:38

Git撤銷

2023-10-12 07:06:32

2020-11-17 10:38:40

云計算工具技術(shù)

2023-10-12 09:42:44

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产精品亚洲第一区在线暖暖韩国 | xx视频在线观看 | 国产三级| 欧美日韩视频在线播放 | 国产一区二区影院 | 亚洲国产精品久久 | 日韩成人av在线播放 | 久久久久久久综合色一本 | 亚洲欧美综合精品久久成人 | 国产高清在线观看 | 久操伊人 | 久久一| 国产精品亚洲综合 | 欧美性生交大片免费 | 色爱综合 | 久久久久av| 午夜精品久久久久久不卡欧美一级 | 日韩国产精品一区二区三区 | 久久亚洲春色中文字幕久久久 | 91天堂| 免费在线观看av片 | 国产精品一区二区三区在线 | 久久久久久亚洲精品 | 操人视频在线观看 | 一区二区三区精品视频 | 中文字幕一区二区不卡 | 天天操天天射综合网 | 日韩欧美中文字幕在线观看 | 亚洲在线观看视频 | 国产成人免费视频 | 亚洲婷婷六月天 | 亚洲一区视频在线播放 | 成人网av | 日韩视频在线免费观看 | 久久综合久久久 | 天天干夜夜操视频 | 91精品国产91久久综合桃花 | 午夜视频在线 | 伊人狠狠干 | 黄色中文字幕 | 亚洲福利在线视频 |