JavaScript中关于null的一切
JavaScript有2种类型:基本类型(string, booleans number, symbol)和对象。
对象是复杂的数据结构,JS 中最简单的对象是普通对象:一组键和关联值:
let myObject = {
name: '前端小智'
}
但是在某些情况下无法创建对象。 在这种情况下,JS 提供一个特殊值null
—表示缺少对象。
let myObject = null
1. 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
。 返回nul
l是合理的,因为who
参数没有值。
2. 如何检查null
检查null
值的好方法是使用严格相等运算符:
const missingObject = null;
const existingObject = { message: 'Hello!' };
missingObject === null; // => true
existingObject === null; // => false
missingObject === null
的结果为true
,因为missingObject
变量包含一个null
值。
如果变量包含非空值(例如对象),则表达式existObject === null
的计算结果为false
。
2.1 null 是虚值
null
与false、0、''、undefined、NaN
都是虚值
。如果在条件语句中遇到虚值,那么 JS 将把虚值强制为false
。
Boolean(null); // => false
if (null) {
console.log('null is truthy')
} else {
console.log('null is falsy')
}
2.2 typeof null
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 会抛出一个错误。
所以说我么你想要从一个对象上取属性的时候,要注意判断这个对象可能是null
, 要不然的话可能会出错。
4. null 的替代方法
当无法构造对象时,我们通常的做法是返回null
,但是这种做法有缺点。在执行堆栈中出现null
时,刚必须进行检查。
尝试避免返回 null
的做法:
- 返回默认对象而不是
null
- 抛出错误而不是返回
null
5. null vs undefined
undefined
是未初始化的变量或对象属性的值
null
和undefined
之间的主要区别是,null
表示丢失的对象,而undefined
表示未初始化的状态。
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档