论js中的null和undefined

    最近看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不易发现。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容