登录
首页 >  文章 >  前端

为什么 `window.num` 返回 `undefined` 而 `num` 抛出 `ReferenceError`?

时间:2024-12-27 13:13:06 294浏览 收藏

本篇文章给大家分享《为什么 `window.num` 返回 `undefined` 而 `num` 抛出 `ReferenceError`?》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

为什么 `window.num` 返回 `undefined` 而 `num` 抛出 `ReferenceError`?

js 中的 window 对象的特殊性

在 js 中,window 对象代表当前浏览器的窗口。它提供了全局作用域的访问权,允许开发者轻松访问全局变量和方法。然而,window 对象还有一个鲜为人知且令人困惑的特性:它可以访问不存在的属性。

为什么可以直接通过 window 对象访问不存在的属性?

让我们看一个例子。在给定的代码段中:

console.log(window.num); // undefined
console.log(num); // Uncaught ReferenceError: num is not defined

window.num 返回 undefined,这表明 num 属性不存在。但是,直接使用 num 却会抛出一个 referenceerror。这是为什么呢?

这种特性实际上是 js 语言设计的一部分。当通过 . 语法访问一个不存在的属性时,js 引擎会首先在当前作用域中查找。如果没有找到,它将继续搜索原型链。

window 对象是全局对象,位于原型链的顶端。因此,当它找不到一个属性时,它将返回 undefined 而不是抛出错误。

执行原理

js 通过以下步骤执行 . 语法访问属性:

  1. 在当前作用域中查找属性。
  2. 如果未找到,则沿着原型链向上搜索。
  3. 如果在原型链中找到属性,则返回它的值。
  4. 如果在原型链中未找到属性,则返回 undefined。

[[getownproperty]] 方法用于在对象或原型链中检索一个属性。如果属性存在,[[getownproperty]] 就会返回其值,否则就返回 undefined。

综上所述,window 对象可以点出任意名称的属性是因为 js 会自动搜索原型链,并返回不存在属性的 undefined 值。

到这里,我们也就讲完了《为什么 `window.num` 返回 `undefined` 而 `num` 抛出 `ReferenceError`?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>