美文网首页
论js中的null和undefined

论js中的null和undefined

作者: Erric_Zhang | 来源:发表于2018-01-05 11:29 被阅读0次

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

相关文章

  • 知识点杂谈

    1.js中null和undefined的区别 在js中null和undefined都表示空,但它们还是存在一定区别...

  • 论js中的null和undefined

    最近看review同事的代码,发现他定义一个变量但不赋值时,经常将这个其设为null(let a = null;...

  • JavaScript中Null和Undefined的区别

    JavaScript中Null和Undefined的区别 Null: null是js中的关键字,表示空值,null...

  • js中null和undefined

    老哥们要注意点 null !== undefind null == undefind

  • JS杂记

    1、Undefined 与 Null 的区别 Undefined 与 null 的值相等,但类型不相等。在js中,...

  • javascript基础入门

    javascript中null和undefined   javascript中存在null和undefined,n...

  • 前端之路——JavaScript中的类型

    JavaScript中的类型 null和undefined null和undefined是JavaScript中两...

  • Symbol

    js中除了undefined number function string object null Boolea...

  • js 中null和undefined区别

    上周五上线代码,又踩了一次坑。导致线上bug。为此特意追查了下null和undefined在js中的却别。整理了相...

  • js null和 undefined

    js中存在两种原始数据类型: null 和 undefinedundefined 类型只有一个值,即 undefi...

网友评论

      本文标题:论js中的null和undefined

      本文链接:https://www.haomeiwen.com/subject/ttzpittx.html