一、概念

undefined 表示未定义,就是应该有值但是还没有赋值,连null的值都没有赋予

null 代表空值,空引用。

二、区别

1.  null 和 undefined 虽然值的结果是相等的,但是其所代表的语义是完全不一样的(==是相等的)。

  undefined 代表了某个变量完全不存在,在内存中完全能不存在这个标识符所指向的地址;

  null 代表了内存中是存在这个变量的,只是我在某些情况下需要把这个变量原本的值给覆盖了,将它设置为一个空。

2.  null 转为数值是 0 ;  undefined 转为数值是 NAN(not a number)。

3.  null 通过 typeof 判断类型的时候结果的输出是 object ; 而 undefined 的类型是 undefined 。


那么为什么 typeof null 是 object ?

null 和 undefined 都是js语言的基础数据类型, 都是原始值类型,但是 typeof null 是 object ,是因为不同的对象在底层都表现为二进制,在  JavaScript  中二进制前三位都为 0 的话会被判断为 object  类型,null 的二进制全部都为 0 ,前三位自然也是 0 ,所以执行 typeof 值会返回 object 。


4.  null 是 js 语言的关键字,是不允许用户用来作为标识符声明变量的,但是 undefined 可以,undefined 不是关键字。

在 node 环境中,我们声明的 undefined 会将原本的 undefined 覆盖的,但是在浏览器环境中不会,是因为浏览器中的 undefined 是直接被使用 Object.defineProperty 定义在了全局对象 window 上,默认就已经被配置成为了:值不可修改并且不可以被重新进行配置。

 三、null 和 undefined分别在实际项目中出现的场景有哪些

1、 undefined

   a. 变量被声明了,但是没有被赋值;

   b. 调用函数的时候,应该给函数传参却没有给函数传这个参数打印出来就是 undefined;

   c. 访问一个对象中没有的属性;

   d. 函数没有返回值时,默认就会返回undefined。

2、 null

   a.作为对象原型链的终点出现;

   b.当我们访问一个不存在的dom节点的时候。

 

Logo

基于 Vue 的企业级 UI 组件库和中后台系统解决方案,为数万开发者服务。

更多推荐