本文摘自PHP中文网,作者青灯夜游,侵删。

推荐教程:《JavaScript视频教程》
JavaScript有2种类型:基本类型(string
, booleans
number
, symbol
)和对象。
对象是复杂的数据结构,JS 中最简单的对象是普通对象:一组键和关联值:
1 2 3 |
|
但是在某些情况下无法创建对象。 在这种情况下,JS 提供一个特殊值null
―表示缺少对象。
1 |
|
在本文中,我们将了解到有关JavaScript中null的所有知识:它的含义,如何检测它,null
与undefined
之间的区别以及为什么使用null
造成代码维护困难。
1. null的概念
JS 规范说明了有关null
的信息:
值null
特指对象的值未设置,它是 JS 基本类型 之一,在布尔运算中被认为是falsy
。
例如,函数greetObject()
创建对象,但是在无法创建对象时也可以返回null
:
1 2 3 4 5 6 7 8 9 |
|
但是,在不带参数的情况下调用函数greetObject()
时,该函数返回null
。 返回null
是合理的,因为who
参数没有值。
2. 如何检查null
检查null
值的好方法是使用严格相等运算符:
1 2 3 4 5 |
|
missingObject === null
的结果为true
,因为missingObject
变量包含一个null
值。
如果变量包含非空值(例如对象),则表达式existObject === nul
l的计算结果为false
。
2.1 null 是虚值
null
与false
、0
、''
、undefined
、NaN
都是虚值。如果在条件语句中遇到虚值,那么 JS 将把虚值强制为false
。
1 2 3 4 5 6 7 |
|
2.2 typeof null
typeof value
运算符确定值的类型。 例如,typeof 15是'number'
,typeof {prop:'Value'}
的计算结果是'object'
。
有趣的是,type null
的结果是什么
1 |
|
为什么是'object'
,typoef null
为object
是早期 JS 实现中的一个错误。
要使用typeof
运算符检测null
值。 如前所述,使用严格等于运算符myVar === null
。
如果我们想使用typeof
运算符检查变量是否是对象,还需要排除null
值:
1 2 3 4 5 6 7 |
|
3. null 的陷阱
null
经常会在我们认为该变量是对象的情况下意外出现。然后,如果从null
中提取属性,JS 会抛出一个错误。
再次使用greetObject()
函数,并尝试从返回的对象访问message
属性:
1 2 3 4 |
|
因为who
变量是一个空字符串,所以该函数返回null
。 从null
访问message
属性时,将引发TypeError
错误。
可以通过使用带有空值合并的可选链接来处理null
:
1 2 3 4 |
|
4. null 的替代方法
当无法构造对象时,我们通常的做法是返回null
,但是这种做法有缺点。在执行堆栈中出现null
时,刚必须进行检查。
尝试避免返回 null
的做法:
- 返回默认对象而不是
null
- 抛出错误而不是返回
null
回到开始返回greeting
对象的greetObject()
函数。缺少参数时,可以返回一个默认对象,而不是返回null
:
1 2 3 4 5 6 7 8 9 |
|
或者抛出一个错误:
1 2 3 4 5 6 7 8 9 |
|
这两种做法可以避免使用 null
。
5. null
vs undefined
undefined
是未初始化的变量或对象属性的值,undefined
是未初始化的变量或对象属性的值。
1 2 3 |
|
null
和undefined
之间的主要区别是,null
表示丢失的对象,而undefined
表示未初始化的状态。
严格的相等运算符===
区分null
和undefined
:
1 |
|
而双等运算符==
则认为null
和undefined
相等
1 |
|
我使用双等相等运算符检查变量是否为null
或undefined
:
1 2 3 4 5 6 7 8 |
|
6. 总结
null
是JavaScript中的一个特殊值,表示丢失的对象,严格相等运算符确定变量是否为空:variable === null
。
typoef
运算符对于确定变量的类型(number
, string
, boolean
)很有用。 但是,如果为null
,则typeof会产生误导:typeof null
的值为'object'
。
null
和undefined
在某种程度上是等价的,但null
表示缺少对象,而undefined
未初始化状态。
更多编程相关知识,请访问:编程视频课程!!
以上就是深入了解JavaScript中的null的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
怎样用 tensorflow.js 创建基本的 ai 模型?
更多相关阅读请进入《javascript》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者