最近看review同事的代码,发现他定义一个变量但不赋值时,经常将这个其设为null(let a = null;),而非我经常只定义不赋值时的undefined(let a;),所以下意识的就得自己一定是忽略了什么,于是花了点点时间来了解了下二者的却别,带着下面的问题为,我们来开始我们的剖析。
定义变量但"不赋值"的话,到底需不需要将其设为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
二、既然二者如此相似,为什么js还要设置这样的两个值?
原来JavaScript诞生之初,最初像Java一样,只设置了null作为表示"无"的值。
① null像在Java里一样,被当成一个对象。但是,JavaScript的数据类型分成基本类型和引用类型两大类,Brendan Eich觉得表示"无"的值最好不是对象。
② JavaScript的最初版本没有包括错误处理机制,发生数据类型不匹配时,往往是自动转换类型或者默默地失败。Brendan Eich觉得,如果null自动转为0(Number(null) =====> 输出0),很不容易发现错误,所以Brendan Eich又设计了一个undefined(Number(undefined) =====> 输出NaN)。
三、二者目前的用法
null表示"没有对象",即该处不应该有值。典型用法:
① 作为函数的参数,表示该函数的参数不是对象;
② 大家都知道js对象的老祖宗Object.prototype,但是大家有没想过Object.prototype.__proto__是什么值,其实是null,而非undefined;
undefined表示"缺少值",就是此处应该有一个值,但是还没有定义。典型用法:
① 变量被声明了,但没有赋值时,就等于undefined;
② 调用函数时,应该提供的参数没有提供,该参数等于undefined;
③ 对象没有赋值的属性,该属性的值为undefined;
④ 函数没有返回值时,默认返回undefined;
综上几点看来,个人觉得声明的变量未赋值时还是按其默认的undefined为好(若确定这个变量后面会被赋值成一个对象,设null也可),强行解释,原由如下:
① 减少代码量;
② 通常值设为null表示其值后面会设为一个对象,但是js作为一个弱类型的语言,变量有时基本类型引用类型都有可能被赋值上;
③ null在做计算操作时会被转换成0参与计算,当定义的变量没被赋上值,且参与了计算,页面不会报错,出现了bug不易发现。