当前位置:首页 > 杂谈 > 正文内容

深入探究:null 和 undefined 究竟有何区别?-null和null区别

2023-07-13 11:01:01TONY杂谈99

简单区分

总的来说 nullundefined 都代表空,主要区别在于 undefined 表示尚未初始化的变量的值,而 null 表示该变量有意缺少对象指向。

undefined这个变量从根本上就没有定义隐藏式 空值null这个值虽然定义了,但它并未指向任何内存中的对象声明式 空值MDN 中给出的定义null

null 是一个字面量,不像 undefined ,它不是全局对象的一个属性。null 是表示缺少的标识,指示变量未指向任何对象。把 null 作为尚未创建的对象,也许更好理解。在 API 中,null 常在返回类型应是一个对象,但没有关联的值的地方使用。

undefined

undefined全局对象 的一个属性。也就是说,它是全局作用域的一个变量。undefined 的最初值就是原始数据类型 undefined

一张神奇的图片

接下来我们看一张比较经典的图片,该图来自 stackoverflow 的回答,本人没有找到准确的出处。

表现形式

在更深入理解 nullundefined 的区别前,我们首先要知道 nullundefinedJS 中有什么不同的表现形式,用以方便我们更好的理解 nullundefined 的区别。

typeoftypeof null // object typeof undefined // undefined Object.prototype.toString.calltypeof null // [object Null] typeof undefined // [object Undefined] == 与 ===null == undefined // true null === undefined // false !!null === !!undefined // true Object.getPrototypeOf(Object.prototype)

JavaScript 中第一个对象的原型指向 null

Object.getPrototypeOf(Object.prototype) // null + 运算 与 Number()let a = undefined + 1 // NaN let b = null + 1 // 1 Number(undefined) // NaN Number(null) // 0 JSONJSON.stringify({a: undefined}) // {} JSON.stringify({b: null}) // {b: null} JSON.stringify({a: undefined, b: null}) // {b: null} let undefiend = testfunction test(n) { let undefined = test return n === undefined } test() // false test(undefined) // false test(test) // ture let undefined = test // Uncaught SyntaxError: Identifier undefined has already been declared 深入探索为什么 typeof null 是 object?

typeof null 输出为 object 其实是一个底层的错误,但直到现阶段都无法被修复。

原因是,在 JavaScript 初始版本中,值以 32位 存储。前 3位 表示数据类型的标记,其余位则是值。

对于所有的对象,它的前 3位 都以 000 作为类型标记位。在 JavaScript 早期版本中, null 被认为是一个特殊的值,用来对应 C 中的 空指针 。但 JavaScript 中没有 C 中的指针,所以 null 意味着什么都没有或者 void 并以 全0(32个) 表示。

因此每当 JavaScript 读取 null 时,它前端的 3位 将它视为 对象类型 ,这也是为什么 typeof null 返回 object 的原因。

为什么 Object.prototype.toString.call(null) 输出 [object Null]

toString()Object 的原型方法,调用该方法,默认返回当前对象的 [[Class]] 。这是一个内部属性,其格式为 [object Xxx] ,其中 Xxx 就是对象的类型。

JavaScript 万物皆对象,为什么 xxx.toString() 不能返回变量类型?

这是因为 各个类中重写了 toString 的方法,因此需要调用 Object 中的 toString 方法,必须使用 toString.call() 的方式调用。

对于 Object 对象,直接调用 toString() 就能返回 [object Object] 。而对于其他对象,则需要通过 call / apply 来调用才能返回正确的类型信息。

为什么 == 和 === 对比会出现 true 和 false ?

很多文章说:undefined 的布尔值是 falsenull 的布尔值也是 false ,所以它们在比较时都转化为了 false ,所以 undefined == null

实际上并不是这样的。

ECMA11.9.3 章节中明确告诉我们:

If x is null and y is undefined, return true.

If x is undefined and y is null, return true.

这是 JavaScript 底层的内容了,至于更深入的内容,如果有兴趣可以扒一扒 JavaScript 的源码。

为什么null + 1和undefined + 1表现不同?

这涉及到 JavaScript 中的隐式类型转换,在执行 加法运算 前,隐士类型转换会尝试将表达式中的变量转换为 number 类型。如:1 + 1 会得到结果 11

null 转化为 number 时,会转换成 0undefined 转换为 number 时,会转换为 NaN

至于为什么执行如此的转换方式,我猜测是 JavaScript 早期的一个糟糕设计。

从语言学的角度来看:

null 意味着一个明确的没有指向的空值,而 undefined

则意味着一个未知的值。

在某种程度上, 0

意味着数字空值。

这虽然看起来有些牵强,但是我在这一阶段能所最能想到的可能了。为什么 JSON.stringify 会将值为 undefined 的内容删除?

其实这条没有很好的解释方式, JSON 会将 undefined 对应的 key 删除,这是 JSON 自身的转换原则。

undefined 的情况下,有无该条数据是没有区别的,因为他们在表现形式上并无不同:

let obj1 = { a: undefined } let obj2 = {} console.log(obj1.a) // undefined console.log(obj2.a) // undefined

但需要注意的是,你可能在调用接口时,需要对 JSON 格式的数据中的 undefied 进行特殊处理。

为什么 let undefiend = test 可以覆盖掉 JavaScript 自身的 undefined?

JavaScript 对于 undefined 的限制方式为全局创建了一个只读的 undefined ,但是并没有彻底禁止局部 undefined 变量的定义。

据说在 JavaScript 高版本禁止了该操作,但我没有准确的依据。

请在任何时候,都不要进行 undefined 变量的覆盖,就算是你的 JSON 转换将 undefined 转换为 。也不要通过该操作进行,这将是及其危险的行为。

总结关于使用 undefined 还是 null

这是一条公说公有理婆说婆有理的争议内容。

本人更倾向于使用 null ,因为这是显示定义空值的方式。我并不能给出准确的理由。

但关于使用 undefined

我有一条建议:

如果你需要使用 undefined 定义空值,请不要采取以下两种方式:let a;let a = undefined;

进而采取下面这种方式显式声明 undefined

let a = void 0;结语

终于将 undefinednull 的基本区别搞定了。

“深入探究:null 和 undefined 究竟有何区别?-null和null区别” 的相关文章

为什么你养的虎尾兰长不高?赶快看看虎尾兰的正确养护方法

为什么你养的虎尾兰长不高?赶快看看虎尾兰的正确养护方法

虎尾兰好养又好看,净化空气能力强,是很多花友家里都会养的一种绿植。 但是不少花友表示,自己的虎尾兰长得很慢,不像别人家的,叶片又高又壮,很阔气的样子。 长得矮,可能是品种问题 虎尾兰有60多个品种,不少是矮生品种,本身就长不高。短叶虎尾兰、矮生金边、矮罗等等,都属于...

安徽发布快递服务消费提示  公布申诉(投诉)电话

安徽发布快递服务消费提示 公布申诉(投诉)电话

大皖新闻讯 12月26日,安徽省邮政局网发布快递服务消费提示 : 连日来,疫情持续大面积波及邮政快递业,各作业环节受到严重影响,寄递全程时限延长,末端投递承压,用户投诉增多。安徽省邮政管理局加强监测、指挥调度、争取支持、狠抓落实,全力以赴做好邮政快递保通保畅工作,努力满足人民群众对...

快速融资2.5亿,国产ToDesk一路直上,打破德国垄断

快速融资2.5亿,国产ToDesk一路直上,打破德国垄断

2020年初的一场疫情,打的所有人措手不及。许多行业都受到严重冲击,但同时,也有些行业逆势上扬,例如远程控制行业,为了保障疫情下的正常运转,远程办公迅速走进了大家的视野,众多国内外科技公司纷纷入局,直接开启了在线办公浪潮。并且据数据观察:远程控制2022年市场将高达数十亿元!...

IE浏览器将于明年6月“退役” 国内网友:考试报名怎么办

IE浏览器将于明年6月“退役” 国内网友:考试报名怎么办

25年后,微软终于做出了决定,彻底放弃IE浏览器,而这个决定虽然之前官方已经有预告,不过真正放弃后带来的问题是必须要面对的。 多年来,这款老化的网络浏览器基本上没有太多消费者使用,...

微软宣布IE浏览器将正式退役,网友:考试报名咋办?

微软宣布IE浏览器将正式退役,网友:考试报名咋办?

5月16日 微软官方消息称: 6月16日 IE(Internet Explorer)浏览器正式退役 此后由Edge(Microsoft Edge)接力 (截图自微软Edge浏览器官方微博) 消息一出引发网友热议 部分用户对于...

原创
            朱婷经纪人登录微博,透露大量信息,他与郎平竟有如此深的渊源

原创 朱婷经纪人登录微博,透露大量信息,他与郎平竟有如此深的渊源

原标题:朱婷经纪人登录微博,透露大量信息,他与郎平竟有如此深的渊源 朱婷的海外经纪人马可最近正式登陆新浪微博,发布了大量微博内容和多张照片,其间透露了大量信息。世界杯期间,马可亲自来到绍兴,见证朱婷的河豚银行夺冠。马可还与朱婷的黄色粉丝小组进行了热烈的互动,对朱婷在我们的人气印象...