我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript中变量对象的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript中变量对象的示例分析

这篇文章主要介绍JavaScript中变量对象的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

一、变量对象

在函数上下文中,我们用活动对象(activation object, AO)来表示变量对象。

活动对象和变量对象其实是一个东西

  1. 变量对象是规范上的或者说是引擎实现上的,不可在 JavaScript 环境中访问

  2. 只有到当进入一个执行上下文中,这个执行上下文的变量对象才会被激活,所以才叫 activation object 呐,而只有被激活的变量对象,也就是活动对象上的各种属性才能被访问。

这里附上一张貘大对于两者关系的回答:
JavaScript中变量对象的示例分析

我们可以将变量对象的创建过程用代码模拟一下:

我们用普通的对象来表示变量对象

var VO = {}; // 变量对象

而变量对象是执行上下文的一个属性:

activeContext = {  VO: {    // 上下文数据(var, FD, function arguments)  }};

当我们遇到下面的代码时:

var a = 10;function func(x){    var b = 20;}func(30);

对应的变量对象应该是:

// 全局变量对象VO(Global) = {    a: 10,    func: reference to function plus(){}}// func函数上下文的变量对象VO(func functionContext) = {  x: 30,  b: 20};

因为不同执行上下文下的变量对象稍有不同,所以我们分开来说。

二、全局变量对象

我们先了解一个概念,叫全局对象。在 W3School 中也有介绍:

全局对象是预定义的对象,作为 JavaScript 的全局函数和全局属性的占位符。通过使用全局对象,可以访问所有其他所有预定义的对象、函数和属性。

可以通过 this 引用,在客户端 JavaScript 中,全局对象就是 Window 对象。

console.log(this); //Window

全局对象是由 Object 构造函数实例化的一个对象。

console.log(this instanceof Object); // true

预定义了一堆,嗯,一大堆函数和属性。

// 都能生效console.log(Math.random());  //随机数console.log(this.Math.random()); //随机数

作为全局变量的宿主(很牛的样子)

var a = 1;console.log(this.a);// 1

客户端 JavaScript 中,全局对象有 window 属性指向自身。

var a = 1;console.log(window.a); // 1this.window.b = 2;console.log(this.b); // 2

而全局上下文中的变量对象就是全局对象!

三、函数上下文中的变量对象

在函数执行上下文中,VO是不能直接访问的,此时由活动对象(activation object,缩写为AO)扮演VO的角色。

VO(functionContext) === AO

活动对象是在进入函数上下文时刻被创建的,它通过函数的arguments属性初始化。arguments属性的值是Arguments对象:

AO = {    arguments: <ArgO>}

Arguments对象是活动对象的一个属性,它包括如下属性:

  1. callee — 指向当前函数的引用

  2. length — 真正传递的参数个数

  3. properties-indexes (字符串类型的整数) 属性的值就是函数的参数值(按参数列表从左到右排列)。

  4. properties-indexes内部元素的个数等于arguments.length. properties-indexes 的值和实际传递进来的参数之间是共享的。

我们来看下面代码:

function foo(x, y, z) {   // 声明的函数参数数量arguments (x, y, z)  alert(foo.length); // 3   // 真正传进来的参数个数(only x, y)  alert(arguments.length); // 2   // 参数的callee是函数自身  alert(arguments.callee === foo); // true   // 参数共享   alert(x === arguments[0]); // true  alert(x); // 10   arguments[0] = 20;  alert(x); // 20   x = 30;  alert(arguments[0]); // 30   // 不过,没有传进来的参数z,和参数的第3个索引值是不共享的  z = 40;  alert(arguments[2]); // undefined   arguments[2] = 50;  alert(z); // 40 } foo(10, 20);
3.1 执行过程

执行上下文的代码会分成两个阶段进行处理:分析和执行,我们也可以叫做:

  1. 进入执行上下文

  2. 代码执行

3.2 进入执行上下文

当进入执行上下文时,这时候还没有执行代码,

变量对象会包括:

  1. 函数的所有形参 (如果是函数上下文)

    • 由名称和对应值组成的一个变量对象的属性被创建

    • 没有实参,属性值设为 undefined

  2. 函数声明

    • 由名称和对应值(函数对象(function-object))组成一个变量对象的属性被创建

    • 如果变量对象已经存在相同名称的属性,则完全替换这个属性

  3. 变量声明

    • 由名称和对应值(undefined)组成一个变量对象的属性被创建;

    • 如果变量名称跟已经声明的形式参数或函数相同,则变量声明不会干扰已经存在的这类属性

举个例子:

function foo(a) {  var b = 2;  function c() {}  var d = function() {};  b = 3;}foo(1);

在进入执行上下文后,这时候的 AO 是:

AO = {    arguments: {        0: 1,        length: 1    },    a: 1,    b: undefined,    c: reference to function c(){},    d: undefined}
3.3 代码执行

在代码执行阶段,会顺序执行代码,根据代码,修改变量对象的值

还是上面的例子,当代码执行完后,这时候的 AO 是:

AO = {    arguments: {        0: 1,        length: 1    },    a: 1,    b: 3,    c: reference to function c(){},    d: reference to FunctionExpression "d"}

到这里变量对象的创建过程就介绍完了,让我们简洁的总结我们上述所说:

  1. 全局上下文的变量对象初始化是全局对象;

  2. 函数上下文的变量对象初始化只包括 Arguments 对象;

  3. 在进入执行上下文时会给变量对象添加形参、函数声明、变量声明等初始的属性值;

  4. 在代码执行阶段,会再次修改变量对象的属性值;

思考题

最后让我们看几个例子:

1.第一题

function foo() {    console.log(a);    a = 1;}foo(); // ???function bar() {    a = 1;    console.log(a);}bar(); // ???

第一段会报错:Uncaught ReferenceError: a is not defined

第二段会打印:1

这是因为函数中的 “a” 并没有通过 var 关键字声明,所有不会被存放在 AO 中。

第一段执行 console 的时候, AO 的值是:

AO = {    arguments: {        length: 0    }}

没有 a 的值,然后就会到全局去找,全局也没有,所以会报错。

当第二段执行 console 的时候,全局对象已经被赋予了 a 属性,这时候就可以从全局找到 a 的值,所以会打印 1。

2.第二题

console.log(foo);function foo(){    console.log("foo");}var foo = 1;

会打印函数,而不是 undefined 。

这是因为在进入执行上下文时,首先会处理函数声明,其次会处理变量声明,如果如果变量名称跟已经声明的形式参数或函数相同,则变量声明不会干扰已经存在的这类属性。

以上是“JavaScript中变量对象的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript中变量对象的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

JavaScript中变量对象的示例分析

这篇文章主要介绍JavaScript中变量对象的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、变量对象在函数上下文中,我们用活动对象(activation object, AO)来表示变量对象。活动对象和
2023-06-14

JavaScript中代理对象的示例分析

这篇文章主要介绍JavaScript中代理对象的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!JavaScript 支持 setters 和 getters 已经很长时间了。他们用带有 set 和 get
2023-06-15

javascript中location对象方法的示例分析

这篇文章将为大家详细讲解有关javascript中location对象方法的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。javascript是一种什么语言javascript是一种动态类型、弱类
2023-06-14

JavaScript中防篡改对象的示例分析

小编给大家分享一下JavaScript中防篡改对象的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!javascript是一种什么语言javascript是
2023-06-14

shell中变量的示例分析

小编给大家分享一下shell中变量的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.简介变量是任何一种编程语言都必不可少的组成部分,变量用来存放各种数据
2023-06-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录