JavaScript中关于null的一切
作者:Dmitri Pavluti
译者:前端小智
来源:dmitripavlutin
有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。JavaScript有2种类型:基本类型(
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。
string
, booleans
number
, symbol
)和对象。对象是复杂的数据结构,JS 中最简单的对象是普通对象:一组键和关联值:
let myObject = {
name: '前端小智'
}
但是在某些情况下无法创建对象。 在这种情况下,JS 提供一个特殊值
null
—表示缺少对象。let myObject = null
在本文中,我们将了解到有关JavaScript中null的所有知识:它的含义,如何检测它,
null
与undefined
之间的区别以及为什么使用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;
// => true
existingObject === null;
// => false
missingObject === null
的结果为true
,因为missingObject
变量包含一个null
值。如果变量包含非空值(例如对象),则表达式
existObject === nul
l的计算结果为false
。2.1 null 是虚值
null
与false
、0
、''
、undefined
、NaN
都是虚值。如果在条件语句中遇到虚值,那么 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 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
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
null
和undefined
之间的主要区别是,null
表示丢失的对象,而undefined
表示未初始化的状态。严格的相等运算
符===
区分null
和undefined
:null === undefined // => false
而双等运算符
==
则认为null
和undefined
相等null == undefined // => true
我使用双等相等运算符检查变量是否为
null
或undefined
:function isEmpty(value) {
return value =https://www.it610.com/article/= null;
}isEmpty(42);
// => false
isEmpty({ prop: 'Value' });
// => false
isEmpty(null);
// => true
isEmpty(undefined);
// => true
6. 总结
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。
交流
有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。【JavaScript中关于null的一切】
本文 GitHub https://github.com/qq44924588... 已收录,有一线大厂面试完整考点、资料以及我的系列文章。
文章图片
推荐阅读
- 热闹中的孤独
- Shell-Bash变量与运算符
- JS中的各种宽高度定义及其应用
- 2021-02-17|2021-02-17 小儿按摩膻中穴-舒缓咳嗽
- 深入理解Go之generate
- 异地恋中,逐渐适应一个人到底意味着什么()
- 我眼中的佛系经纪人
- 《魔法科高中的劣等生》第26卷(Invasion篇)发售
- “成长”读书社群招募
- 2020-04-07vue中Axios的封装和API接口的管理