javascript - 请问这段js代码的变量对象是什么?

PHP中文网
Lepaskan: 2016-08-25 10:37:22
asal
1300 orang telah melayarinya

javascript - 请问这段js代码的变量对象是什么?

alert(x); //"x" is not definedalert(b); //"undefined

x = 10;
var y = 20;
Salin selepas log masuk

x是否成为了window的一个属性而非变量?y是变量对象吗?

因为我看到了这么一段话

在《Javascript高级程序设计》4.2.2一节当中有这么一句话:“如果初始化变量时没有使用var声明,该变量会自动被添加到全局环境中。”
首先,我们应该先明确一点,使用var关键字是声明变量的唯一方式。如果没有var 的话,例如 a = 5 ,a就将作为全局对象的一个属性,而不是一个变量。

区别如下:

alert(x); //"x" is not defined alert(b); //"undefined

x = 10; var y = 20;
Salin selepas log masuk
Salin selepas log masuk

进入上下文后第一阶段:

VO = {   x:10; }
Salin selepas log masuk
Salin selepas log masuk

VO 中并没有y的原因是,y 并不是变量。

请问他说的对吗?

回复内容:

alert(x); //"x" is not defined
alert(b); //"undefined

x = 10;
var y = 20;
Salin selepas log masuk

x是否成为了window的一个属性而非变量?
y是变量对象吗?

因为我看到了这么一段话

在《Javascript高级程序设计》4.2.2一节当中有这么一句话:“如果初始化变量时没有使用var声明,该变量会自动被添加到全局环境中。”
首先,我们应该先明确一点,使用var关键字是声明变量的唯一方式。如果没有var 的话,例如 a = 5 ,a就将作为全局对象的一个属性,而不是一个变量。

区别如下:

alert(x); //"x" is not defined alert(b); //"undefined

x = 10; var y = 20;
Salin selepas log masuk
Salin selepas log masuk

进入上下文后第一阶段:

VO = {   x:10; }
Salin selepas log masuk
Salin selepas log masuk

VO 中并没有y的原因是,y 并不是变量。

请问他说的对吗?


直接在下面输出一下有没有不就得了。。。这时候的window是上下文执行环境吧?


肯定不是啊,变量对象(variable object) 是与执行上下文相关的 数据作用域(scope of data) 。
它是与上下文关联的特殊对象,用于存储被定义在上下文中的 变量(variables) 和 函数声明(function declarations) 。你声明、不声明的变量都是变量。
http://www.nowamagic.net/libr...

其实完全没必要去纠结于变量和属性。

alert(x)会报错就是因为x没有使用var声明,不会被前置到变量对象中,当执行x=10的时候才会去给全局对象上添加一个x属性。
Salin selepas log masuk


在浏览器中,定义在全局作用域中的都是window的属性。在这里x与y既是变量,同时又是window的属性,window.x与window.y都能访问到


含义:
变量声明是必须通过 var 语句来完成的,未通过var 语句声明的全局变量是window对象的属性。

区别:
delete操作符是用来删除对象属性的。
通过var声明的变量和通过function声明的函数拥有DontDelete特性,是不能被删除。
未通过var声明的全局变量(全局对象的属性)可以被删除

以上就是javascript - 请问这段js代码的变量对象是什么?的内容,更多相关内容请关注PHP中文网(www.php.cn)!


Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!