本文已经作者@Dmitri Pavluti授权翻译
JavaScript有2种类型:基本类型(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; // => falsemissingObject === 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
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); // => false3. 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; // => undefinednull和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); // => true6. 总结
null是JavaScript中的一个特殊值,表示丢失的对象,严格相等运算符确定变量是否为空:variable === null。
typoef运算符对于确定变量的类型(number, string, boolean)很有用。 但是,如果为null,则typeof会产生误导:typeof null的值为object。
null和undefined在某种程度上是等价的,但null表示缺少对象,而undefined未初始化状态。
作者:Dmitri Pavluti 译者:前端小智 来源:dmitripavlutin原文:https://dmitripavlutin.com/javascript-null/#comments
本文转载自微信公众号「 大迁世界」,可以通过以下二维码关注。转载本文请联系 大迁世界公众号。