javascript作用域

本文深入探讨了JavaScript中的作用域概念,解释了函数作用域而非块级作用域的特点,并通过示例详细介绍了作用域链的工作原理及其如何帮助解析变量。

javascript没有块级作用域,只有函数作用域。javascript代码执行过程中,第一个进入的默认是全局作用域,执行函数的时候会进入该函数的作用域。

函数是Function对象的一个实例,拥有可以编程访问的属性,和一些不能通过代码访问而仅供javascript引擎存取的内部属性。今天要介绍的就是Scope这一内部属性。

在javascript中每一个函数,都有一个scope属性,scope属性的值是一个链表,即该函数的作用域链。

用下面这段代码举例

function test(){
	var a=4;
	var b=2;
	console.log(a+b);
}

test();

当函数被创建时,作用域链的第一个节点就有了,即全局对象,该对象包含诸如this,window,document等全局作用域中的变量。


当函数被执行时,作用域链的原第一个节点,即全局对象,变成第二个节点,新的第一个节点是,活动对象即执行环境(执行上下文),这个对象中包含当前执行函数的变量,参数,this。这些值按照它们出现在函数中的顺序,排列在活动对象内。


注意函数每次执行时对应的执行环境是独一无二的,所以多次调用同一函数会创建多个执行环境。当函数执行完毕,执行环境就被销毁。

众所周知,当函数在内部遇到一个变量,它会先找一找函数内部有没有这个变量的值,如果没有就到上一层去找一找,直到找到全局作用域。这是因为,标识符解析过程,是从作用域链这个链表的头部开始向尾部查找的。头部是该函数作用域,尾部自然是全局作用域。


标题基于Python的汽车之家网站舆情分析系统研究AI更换标题第1章引言阐述汽车之家网站舆情分析的研究背景、意义、国内外研究现状、论文方法及创新点。1.1研究背景与意义说明汽车之家网站舆情分析对汽车行业及消费者的重要性。1.2国内外研究现状概述国内外在汽车舆情分析领域的研究进展与成果。1.3论文方法及创新点介绍本文采用的研究方法及相较于前人的创新之处。第2章相关理论总结和评述舆情分析、Python编程及网络爬虫相关理论。2.1舆情分析理论阐述舆情分析的基本概念、流程及关键技术。2.2Python编程基础介绍Python语言特点及其在数据分析中的应用。2.3网络爬虫技术说明网络爬虫的原理及在舆情数据收集中的应用。第3章系统设计详细描述基于Python的汽车之家网站舆情分析系统的设计方案。3.1系统架构设计给出系统的整体架构,包括数据收集、处理、分析及展示模块。3.2数据收集模块设计介绍如何利用网络爬虫技术收集汽车之家网站的舆情数据。3.3数据处理与分析模块设计阐述数据处理流程及舆情分析算法的选择与实现。第4章系统实现与测试介绍系统的实现过程及测试方法,确保系统稳定可靠。4.1系统实现环境列出系统实现所需的软件、硬件环境及开发工具。4.2系统实现过程详细描述系统各模块的实现步骤及代码实现细节。4.3系统测试方法介绍系统测试的方法、测试用例及测试结果分析。第5章研究结果与分析呈现系统运行结果,分析舆情数据,提出见解。5.1舆情数据可视化展示通过图表等形式展示舆情数据的分布、趋势等特征。5.2舆情分析结果解读对舆情分析结果进行解读,提出对汽车行业的见解。5.3对比方法分析将本系统与其他舆情分析系统进行对比,分析优劣。第6章结论与展望总结研究成果,提出未来研究方向。6.1研究结论概括本文的主要研究成果及对汽车之家网站舆情分析的贡献。6.2展望指出系统存在的不足及未来改进方向,展望舆情
作用域(Scope)是指在代码中定义变量时,这些变量在哪里以及在哪些地方可以被访问,控制着变量的可见性和生命周期。在 JavaScript 中,作用域的类型主要由函数定义和代码块定义来决定[^2]。以下是 JavaScript 作用域的类型介绍: - **全局作用域**:在 `<script>` 标签中或者 js 脚本中定义的变量属于全局作用域。全局作用域中的变量可以在代码的任何地方被访问[^3]。 ```javascript var globalVar = 'I am a global variable'; function testGlobal() { console.log(globalVar); // 可以访问全局变量 } testGlobal(); ``` - **局部作用域**:在函数中定义的变量属于局部作用域,使用 `var` 关键字声明,这些变量只能在函数内部被访问,函数外部无法直接访问这些变量[^3]。 ```javascript function testLocal() { var localVar = 'I am a local variable'; console.log(localVar); // 可以在函数内部访问局部变量 } testLocal(); console.log(localVar); // 报错,无法在函数外部访问局部变量 ``` - **块作用域**:ES6 中在 `{}` 代码块中使用 `let` 或 `const` 定义的常量、变量属于块作用域;而 ES6 之前使用 `var` 关键字在 `{}` 代码块中定义的变量,取决于代码块位置,代码块在全局作用域则该变量属于全局作用域,代码块在局部作用域则该变量属于局部作用域[^3]。 ```javascript // 使用 let 声明,具有块级作用域 if (true) { let blockVar = 'I am a block variable'; console.log(blockVar); // 可以在代码块内部访问 } console.log(blockVar); // 报错,无法在代码块外部访问 // 使用 var 声明,没有块级作用域 if (true) { var oldStyleVar = 'I am declared with var'; } console.log(oldStyleVar); // 可以访问 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值