美文网首页
js关于变量对象的理解

js关于变量对象的理解

作者: a4316976150e | 来源:发表于2017-02-20 02:08 被阅读0次

当调用一个函数时,一个新的执行上下文就会被创建,执行上下文的生命周期为两个部分,一个是创建部分:创建变量对象,确定它的作用域链,确定它的this的指向。二个是执行部分,确定变量对象的值。然后将函数引用,执行其他代码。

变量对象的创建过程:

1,建立一个argunments对象,寻找当前上下文中的参数,并以其参数名以及参数值创建一个属性。

2,寻找当前上下文当中的function声明,在变量对象中,以函数名为属性名,创建以个属性,值为函数的引用地址,如果函数名重复的话,后面的覆盖前面的

3,寻找当前上下文当中的var声明,在变量对象中,以变量名为其属性名,创建以个属性,值为undefined

例子

function  test(){

console.log(foo);

console.log(bar);

var   foo ='Hello';

console.log(foo);

var  bar =function(){

return'world';    

}

function  foo(){

return'hello';    

}

}

test();

如上例子创建执行上下文时,AO和VO两部分的区别

AO{

arguments:没有参数;

function: foo():值为其引用

var:foo和bar,值为undefined

}

VO{

arguments:空;

function:foo():值为引用

var bar = 其引用;foo = hello,还有一个函数属性名为它本身

}

此时有一个变量声明foo为undefined,一个函数声明foo为它自己,后面的函数声明覆盖掉了前面的变量声明,所以当conlose foo的时候,返回整个foo函数,当第二个console foo的时候,此时已经将值付给了foo所以foo为hello

如果是这样写foo的值将为hello

全局环境中的变量对象

它的变量对象为window,变量之类的都为它的属性,它的this也指向它自己

除此之外,全局上下文的生命周期,与程序的生命周期一致,只要程序运行不结束,比如关掉浏览器窗口,全局上下文就会一直存在。其他所有的上下文环境,都能直接访问全局上下文的属性。

相关文章

  • js关于变量对象的理解

    当调用一个函数时,一个新的执行上下文就会被创建,执行上下文的生命周期为两个部分,一个是创建部分:创建变量对象,确定...

  • react 对象动态添加属性 setState

    // js 对象动态添加 js对象动态添加 //总结,给对象动态添加变量属性的方法如下: //obj[变量]=变...

  • 预编译阶段变量函数的提升 和 多个函数的执行顺序

    下面这道题讲解变量和函数的提升 预编译js的变量对象 AO对象 让js引擎去访问1、创建AO对象2、找形参和变量的...

  • js中的数组

    1.关于js中的array对象 Array对象是用于在单个的变量中存储多个值; js数组中的每一项在都能保存任何类...

  • 6.JavaScript中

    JS对象创建: JS通过构造函数创建对象: JS内置对象window: 所有的全局变量都是window的属性 所有...

  • JS变量对象

    写在前面的话 接触前端到现在大概也有三个多月了,越深入学习越发现自己理解的学到的只是一知半解。于是翻阅了许多大神如...

  • JS变量对象

    当调用一个函数时,一个新的执行上下文就会被创建,每一个执行上下文都有3个基本属性:变量对象,作用域链、this ...

  • 如何确定js里的this

    在我的彻底理解js的执行上下文,以及变量对象中我说过,执行上下文是在函数被调用的时候被创建的,其中包括创建变量对象...

  • 2018-10-11:JS与jQuery基础

    JS基础 Java: 面向对象 编译型 强变量 服务器JS: 基于对象 解释型 弱变量 客户端 编译和解释:编...

  • js的深拷贝与浅拷贝及实现方法

    前提 理解深拷贝和浅拷贝之前,我们先理解下js变量的存储方式。 js变量分为基础类型(Undefined、Null...

网友评论

      本文标题:js关于变量对象的理解

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