做者:Dmitri Pavluti
譯者:前端小智
來源:dmitripavlutin
本文已通過做者@Dmitri Pavluti受權翻譯javascript
點贊再看,微信搜索
【大遷世界】 關注這個沒有大廠背景,但有着一股向上積極心態人。本文
GitHub
https://github.com/qq44924588... 上已經收錄,文章的已分類,也整理了不少個人文檔,和教程資料。
JavaScript有2種類型:基本類型(string
, booleans
number
, symbol
)和對象。java
對象是複雜的數據結構,JS 中最簡單的對象是普通對象:一組鍵和關聯值:git
let myObject = { name: '前端小智' }
可是在某些狀況下沒法建立對象。 在這種狀況下,JS 提供一個特殊值null
—表示缺乏對象。github
let myObject = null
在本文中,咱們將瞭解到有關JavaScript中null的全部知識:它的含義,如何檢測它,null
與undefined
之間的區別以及爲何使用null
形成代碼維護困難。微信
JS 規範說明了有關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
。 返回null
是合理的,由於who
參數沒有值。工具
檢查null
值的好方法是使用嚴格相等運算符:spa
const missingObject = null; const existingObject = { message: 'Hello!' }; missingObject === null; // => true existingObject === null; // => false
missingObject === null
的結果爲true
,由於missingObject
變量包含一個null
值。
若是變量包含非空值(例如對象),則表達式existObject === nul
l的計算結果爲false
。
null
與false
、0
、''
、undefined
、NaN
都是虛值。若是在條件語句中遇到虛值,那麼 JS 將把虛值強制爲false
。
Boolean(null); // => false if (null) { console.log('null is truthy') } else { console.log('null is falsy') }
typeof value
運算符肯定值的類型。 例如,typeof 15是'number'
,typeof {prop:'Value'}
的計算結果是'object'
。
有趣的是,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 會拋出一個錯誤。
再次使用greetObject()
函數,並嘗試從返回的對象訪問message
屬性:
let who = ''; greetObject(who).message; // throws "TypeError: greetObject() is null"
由於who
變量是一個空字符串,因此該函數返回null
。 從null
訪問message
屬性時,將引起TypeError
錯誤。
能夠經過使用帶有空值合併的可選連接來處理null
:
let who = '' greetObject(who)?.message ?? 'Hello, Stranger!' // => 'Hello, Stranger!'
當沒法構造對象時,咱們一般的作法是返回null
,可是這種作法有缺點。在執行堆棧中出現null
時,剛必須進行檢查。
嘗試避免返回 null
的作法:
null
null
回到開始返回greeting
對象的greetObject()
函數。缺乏參數時,能夠返回一個默認對象,而不是返回null
:
function greetObject(who) { if (!who) { who = 'Stranger'; } return { message: `Hello, ${who}!` }; } greetObject('Eric'); // => { message: 'Hello, Eric!' } greetObject(); // => { message: 'Hello, Stranger!' }
或者拋出一個錯誤:
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
。
null
vs undefined
undefined
是未初始化的變量或對象屬性的值,undefined
是未初始化的變量或對象屬性的值。
let myVariable; myVariable; // => undefined
null
和undefined
之間的主要區別是,null
表示丟失的對象,而undefined
表示未初始化的狀態。
嚴格的相等運算符===
區分null
和undefined
:
null === undefined // => false
而雙等運算符==
則認爲null
和undefined
相等
null == undefined // => true
我使用雙等相等運算符檢查變量是否爲null
或undefined
:
function isEmpty(value) { return value == null; } isEmpty(42); // => false isEmpty({ prop: 'Value' }); // => false isEmpty(null); // => true isEmpty(undefined); // => true
null
是JavaScript中的一個特殊值,表示丟失的對象,嚴格相等運算符肯定變量是否爲空:variable === null
。
typoef
運算符對於肯定變量的類型(number
, string
, boolean
)頗有用。 可是,若是爲null
,則typeof會產生誤導:typeof null
的值爲'object'
。
null
和undefined
在某種程度上是等價的,但null
表示缺乏對象,而undefined
未初始化狀態。
原文:https://dmitripavlutin.com/ja...
代碼部署後可能存在的BUG無法實時知道,過後爲了解決這些BUG,花了大量的時間進行log 調試,這邊順便給你們推薦一個好用的BUG監控工具 Fundebug。
文章每週持續更新,能夠微信搜索 【大遷世界 】 第一時間閱讀,回覆 【福利】 有多份前端視頻等着你,本文 GitHub https://github.com/qq449245884/xiaozhi 已經收錄,歡迎Star。