作者:Dmitri Pavluti
译者:前端小智
起源:dmitripavlutin

有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。

JavaScript有2种类型:根本类型(string, booleans number, symbol)和对象。

对象是简单的数据结构,JS 中最简略的对象是一般对象:一组键和关联值:

let myObject = {  name: '前端小智'}

然而在某些状况下无奈创建对象。 在这种状况下,JS 提供一个非凡值null —示意短少对象。

let myObject = null

在本文中,咱们将理解到无关JavaScript中null的所有常识:它的含意,如何检测它,nullundefined之间的区别以及为什么应用null造成代码保护艰难。

1. 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参数没有值。

2. 如何查看null

查看null值的好办法是应用严格相等运算符:

const missingObject = null;const existingObject = { message: 'Hello!' };missingObject  === null; // => trueexistingObject === null; // => false

missingObject === null的后果为true,因为missingObject变量蕴含一个null 值。

如果变量蕴含非空值(例如对象),则表达式existObject === null的计算结果为false

2.1 null 是虚值

nullfalse0''undefinedNaN都是虚值。如果在条件语句中遇到虚值,那么 JS 将把虚值强制为false

Boolean(null); // => falseif (null) {  console.log('null is truthy')} else {  console.log('null is falsy')}

2.2 typeof null

typeof value运算符确定值的类型。 例如,typeof 15是'number'typeof {prop:'Value'}的计算结果是'object'

乏味的是,type null的后果是什么

typeof null; // => 'object'

为什么是'object'typoef nullobject是晚期 JS 实现中的一个谬误。

要应用typeof运算符检测null值。 如前所述,应用严格等于运算符myVar === null

如果咱们想应用typeof运算符查看变量是否是对象,还须要排除null值:

function isObject(object) {  return typeof object === 'object' && object !== null;}isObject({ prop: 'Value' }); // => trueisObject(15);                // => falseisObject(null);              // => false

3. null 的陷阱

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!'

4. null 的代替办法

当无奈结构对象时,咱们通常的做法是返回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

5. null vs undefined

undefined是未初始化的变量或对象属性的值,undefined是未初始化的变量或对象属性的值。

let myVariable;myVariable; // => undefined

nullundefined之间的次要区别是,null示意失落的对象,而undefined示意未初始化的状态。

严格的相等运算符===辨别nullundefined :

null === undefined // => false

而双等运算符==则认为nullundefined 相等

null == undefined // => true

我应用双等相等运算符查看变量是否为nullundefined:

function isEmpty(value) {  return value == null;}isEmpty(42);                // => falseisEmpty({ prop: 'Value' }); // => falseisEmpty(null);              // => trueisEmpty(undefined);         // => true

6. 总结

null是JavaScript中的一个非凡值,示意失落的对象,严格相等运算符确定变量是否为空:variable === null

typoef运算符对于确定变量的类型(number, string, boolean)很有用。 然而,如果为null,则typeof会产生误导:typeof null的值为'object'

nullundefined在某种程度上是等价的,但null示意短少对象,而undefined未初始化状态。


原文:https://dmitripavlutin.com/ja...

代码部署后可能存在的BUG没法实时晓得,预先为了解决这些BUG,花了大量的工夫进行log 调试,这边顺便给大家举荐一个好用的BUG监控工具 Fundebug。

交换

有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq44924588... 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。