菜单

402.com论js中的null和undefined

2019年9月11日 - 计算机教程

有点奇怪的是,JavaScript语言居然有两个表示”无”的值:undefined和null。这是为什么?

   
最近看review同事的代码,发现他定义一个变量但不赋值时,经常将这个其设为null(let
a = null;),而非我经常只定义不赋值时的undefined(let
a;),所以下意识的就得自己一定是忽略了什么,于是花了点点时间来了解了下二者的却别,带着下面的问题为,我们来开始我们的剖析。

一、相似性
在JavaScript中,将一个变量赋值为undefined或null,老实说,几乎没区别。

定义变量但”不赋值”的话,到底需不需要将其设为null?

复制代码 代码如下:

一、相似性

   
老实说在js中将一个变量设为null或undefined几乎没什么区别,几乎是等价的。在if语句中二者都会被转化成false,做相等运算时,二者还相等。 

    if (null) { console.log(‘null is false’) }    =====>    输出’null
is false’

    if (undefined) { console.log(‘null is false’) }    =====>   
输出’undefined is false’

    undefined  == null    =====>    输出true

var a = undefined;
var a = null;

二、既然二者如此相似,为什么js还要设置这样的两个值?

   
原来JavaScript诞生之初,最初像Java一样,只设置了null作为表示”无”的值。
    ①
null像在Java里一样,被当成一个对象。但是,JavaScript的数据类型分成基本类型和引用类型两大类,Brendan
Eich觉得表示”无”的值最好不是对象。
   
② JavaScript的最初版本没有包括错误处理机制,发生数据类型不匹配时,往往是自动转换类型或者默默地失败。Brendan
Eich觉得,如果null自动转为0(Number(null)  =====> 
输出0),很不容易发现错误,所以Brendan
Eich又设计了一个undefined(Number(undefined)  =====>  输出NaN)。

上面代码中,a变量分别被赋值为undefined和null,这两种写法几乎等价。
undefined和null在if语句中,都会被自动转为false,相等运算符甚至直接报告两者相等。

三、二者目前的用法

    null表示”没有对象”,即该处不应该有值。典型用法:
    ① 作为函数的参数,表示该函数的参数不是对象;
    ②
大家都知道js对象的老祖宗Object.prototype,但是大家有没想过Object.prototype.__proto__是什么值,其实是null,而非undefined;

   
undefined表示”缺少值”,就是此处应该有一个值,但是还没有定义。典型用法:
    ① 变量被声明了,但没有赋值时,就等于undefined;
    ② 调用函数时,应该提供的参数没有提供,该参数等于undefined;
    ③ 对象没有赋值的属性,该属性的值为undefined;
    ④ 函数没有返回值时,默认返回undefined;

   
综上几点看来,个人觉得声明的变量未赋值时还是按其默认的undefined为好(若确定这个变量后面会被赋值成一个对象,设null也可),强行解释,原由如下:
    ① 减少代码量;
    ②
通常值设为null表示其值后面会设为一个对象,但是js作为一个弱类型的语言,变量有时基本类型引用类型都有可能被赋值上;
   ③
null在做计算操作时会被转换成0参与计算,当定义的变量没被赋上值,且参与了计算,页面不会报错,出现了bug不易发现。

复制代码 代码如下:

if (!undefined)
    console.log(‘undefined is false’);
// undefined is false

if (!null)
    console.log(‘null is false’);
// null is false

undefined == null
// true

上面代码说明,两者的行为是何等相似!
既然undefined和null的含义与用法都差不多,为什么要同时设置两个这样的值,这不是无端增加JavaScript的复杂度,令初学者困扰吗?Google公司开发的JavaScript语言的替代品Dart语言,就明确规定只有null,没有undefined!
二、历史原因
最近,我在读新书《Speaking JavaScript》时,意外发现了这个问题的答案!
原来,这与JavaScript的历史有关。1995年JavaScript诞生时,最初像Java一样,只设置了null作为表示”无”的值。
根据C语言的传统,null被设计成可以自动转为0。

复制代码 代码如下:

Number(null)
// 0

5 + null
// 5

但是,JavaScript的设计者Brendan Eich,觉得这样做还不够,有两个原因。
首先,null像在Java里一样,被当成一个对象。

复制代码 代码如下:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图