网站首页 > 知识剖析 正文
本文已经作者@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; // => 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
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 == 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未初始化状态。
作者:Dmitri Pavluti 译者:前端小智 来源:dmitripavlutin
原文:https://dmitripavlutin.com/javascript-null/#comments
分享一套 《商业级应用-微信小程序开发实战》,这是一次纯正的实战,不模拟、不虚构,以极致的产品体验完美的细节处理,带你开发“完全真实”的小程序。有谁需要的话,我可以免费分享给你。领取方式:收藏+转发+点赞,然后私信我回复 "小程序" 即可获取。
猜你喜欢
- 2025-01-18 JS 高手进阶:玩转七种继承艺术
- 2025-01-18 关于JavaScript必学的基础知识(上)
- 2025-01-18 记好这 24 个 ES6 方法,用来解决实际开发的 JS 问题
- 2025-01-18 JS入门基础知识
- 2025-01-18 vue 开发规范
- 2025-01-18 面试遇到 性能优化 必答的 9 个点,加分!
- 2025-01-18 我不知道还可以用 JS 做的 6 件事
- 2025-01-18 织梦后台如何使用sql语句给dedecms模板添加自定义属性
- 2025-01-18 自学Python的学习顺序,知识要点
- 2025-01-18 玩转浏览器自动化(9)使用 Playwright.NUnit 编写测试
- 04-29php开发者composer使用看这一篇就够了
- 04-29引用和变量声明在不同语言中的实作
- 04-29PHP 没你想的那么差
- 04-29Ubuntu linux 上的 Nginx 和 Php 安装
- 04-29CentOS下通过yum搭建lnmp(单版本PHP)
- 04-29为什么 PHP8 是个高性能版本
- 04-29PHP8函数包含文件-PHP8知识详解
- 04-29使用无参数函数进行命令执行
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)