作者:Dmitri Pavluti
译者:前端小智
起源:dmitripavlutin
本文曾经过作者@Dmitri Pavluti受权翻译
点赞再看,微信搜寻 【大迁世界】 关注这个没有大厂背景,但有着一股向上踊跃心态人。本文 GitHub
https://github.com/qq44924588... 上曾经收录,文章的已分类,也整顿了很多我的文档,和教程材料。
大家都说简历没我的项目写,我就帮大家找了一个我的项目,还附赠【搭建教程】。
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; // => trueexistingObject === 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' }); // => trueisObject(15); // => falseisObject(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); // => falseisEmpty({ prop: 'Value' }); // => falseisEmpty(null); // => trueisEmpty(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。
交换
文章每周继续更新,能够微信搜寻 【大迁世界 】 第一工夫浏览,回复 【福利】 有多份前端视频等着你,本文 GitHub https://github.com/qq449245884/xiaozhi 曾经收录,欢送Star。