搜索
首页web前端js教程Javascript中的作用域和上下文深入理解_javascript技巧

概述

Javascript中的作用域和上下文的实现是Javascript语言独有的特性,从某种程度上来说,Javascript语言是十分灵活的。Javascript中的函数可以采用各种各样的上下文,作用域也可以被封装和保存。正是由于这些特性,Javascript中也提供了很多很有用的设计模式。然而,作用域和上下文也是Javascript程序员在开发中经常迷惑的地方。
下面会向大家介绍Javascript中作用域和上下文的概念,以及它们的不同。

作用域 VS 上下文

首先要说明的很重要的一点是作用域和上下文并不是同一个概念,它们指代的并不是同一个东西。作为一个前端的菜逼,经常会看到一些文章把这两个概念弄混,结果有些东西越看越不明白。这两个概念貌似被混淆了很长一段时间了。因此,查了很多资料,简单说明下这两个概念。:stuck_out_tongue_closed_eyes:
在Javascript中,当一个函数被调用时都会有一个作用域和上下文和这个函数绑定在一起。从根本上来说,作用域是基于函数的而上下文是基于对象的。换句话说,作用域适用于函数被调用时函数中变量的访问权限。上下文通常是指“this”关键字的值,“this”是拥有当前执行代码的对象的引用。

变量作用域

变量可以被定义在局域或全局作用域中,分别称为局部变量和全局变量。全局变量是指在函数体外声明的变量,在程序的任何地方都可以访问全局变量。局部变量是指在函数体内定义的变量,它仅可以在函数体内或者嵌套的函数内被访问,并且不能在函数外部被访问。
Javascript目前并不支持块级作用域(在if、switch、for等语句中定义的变量)。这意味着在块内定义的变量,在块外也可以访问。但是,在ES6中,我们可以使用“let”关键字定义块级作用域。
关于作用域的内容,大家可以查下别的资料,这部分内容相对简单些。

“this”上下文

上下文(context)通常取决于函数被调用的方式。当函数作为对象的方法被调用时,“this”指代的是调用该函数的对象。

复制代码 代码如下:

var obj={
    foo:function (){
        console.log(this === obj);
    }
};
obj.foo();   //输出true

同样,当我们使用“new”关键字创建新对象时,this引用的是新创建的对象。
复制代码 代码如下:

function foo(){
    console.log(this);
}
foo();         //输出window
var obj=new foo();     //输出 foo {}

有一点需要注意的是,当全局作用域中的函数被被调用时,this引用的是全局对象,在浏览器环境中指的就是window。但是,如果在严格模式下运行代码时,“this”被设置为“undefined”
执行上下文(Execution Context)

Javascript是单线程的语言,这也就是说Javascript在浏览器中运行时,一次只能做一件事情,其他的事情将被方法队列中,等待被处理。

1.当Javascript代码文件被浏览器载入后,默认最新进入的是一个全局的执行上下文。当在全局上下文中调用一个函数时,程序留就进入该被调用函数内,此时Javascript引擎就会为该函数创建一个新的执行上下文,并且将其压入到执行上下文堆栈的顶部。浏览器总是执行当前在堆栈顶部的上下文,一旦执行完毕,该上下文就会从堆栈顶部被弹出,然后,进入其下的上下文执行代码。这样,堆栈中的上下文就会被依次执行并且弹出堆栈,直到回到全局的上下文。

2.一个执行上下文可以被分为两个阶段:创建阶段和执行阶段。在创建阶段,javascript解释器首先会创建一个变量对象(也成为“活动对象”,activation object)。活动对象由变量,函数声明和参数组成。在这个阶段,函数的作用域链被初始化,this引用的对象也被确定。接下来就是执行阶段,在这个阶段,代码被解释并执行。
在Javascript代码中,可以有任意多个函数上下文,我们已经知道,当函数被调用时,Javascript解释器就会创建一个新的上下文,同时会创建一个私有的作用域,函数内部声明的任何变量都不能在当前函数作用域外部直接访问。

3.通过上面的解释,我们对函数的“执行上下文”有了一个基本的概念,但是这里也是大家最容易迷惑的一个地方。Javascript中的“执行上下文”主要是指作用域,而不是上面第四小节中指的“this上下文”。类似的容易混淆的概念在Javascript中还有很多,但是我们只要弄清楚了每个概念所指代的具体对象,就不会再迷惑,因此,这里也希望大家能够真正的区分开“执行上下文”和“this上下文”。

简单的一句话概括来说,执行上下文是与作用域相关的概念,虽然这样说可能不太严谨。

作用域链

对每一个执行上下文来说,都有一个作用域连跟它绑定在一起。作用域链包含了执行上下文堆栈中的执行上下文活动对象(activation object,听起来有点绕口)。作用域链决定了变量的访问和标识符的解析。

代码示例:

复制代码 代码如下:

function first(){
    second();
    function second(){
        third();
        function third(){
            fourth();
            function fourth(){
                //代码
            }
        }
    }
}
first();

执行上面的代码,嵌套的函数都会被执行。就上面的代码来说,也会形成一个作用域链,作用域链从顶部到底部的顺序为:fourth, third, second, first, global。函数fourth可以访问全局作用域中的变量,并且可以访问函数third, second, first中定义的任何变量。
有一点需要注意的是,在函数体内,局部变量的优先级高于同名的全局变量。如果在函数内声明的局部变量或函数参数中带有的变量和全局变量重名,那么全局变量就被局部变量所覆盖。
简单来说,每次我们尝试访问一个变量时,程序都会在当前函数作用域内查找变量,如果找不到就沿着作用域链到该函数的上层去查找,直到找到该变量为止,如果找不到则返回undefined。

总结

这篇文章介绍了javascript中上下文和作用域的相关概念,javascript中还有几个比较重要的概念,如闭包等,这些在以后自己弄明白了会写成文章~~

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python vs. JavaScript:社区,图书馆和资源Python vs. JavaScript:社区,图书馆和资源Apr 15, 2025 am 12:16 AM

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

从C/C到JavaScript:所有工作方式从C/C到JavaScript:所有工作方式Apr 14, 2025 am 12:05 AM

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

JavaScript引擎:比较实施JavaScript引擎:比较实施Apr 13, 2025 am 12:05 AM

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

超越浏览器:现实世界中的JavaScript超越浏览器:现实世界中的JavaScriptApr 12, 2025 am 12:06 AM

JavaScript在现实世界中的应用包括服务器端编程、移动应用开发和物联网控制:1.通过Node.js实现服务器端编程,适用于高并发请求处理。2.通过ReactNative进行移动应用开发,支持跨平台部署。3.通过Johnny-Five库用于物联网设备控制,适用于硬件交互。

使用Next.js(后端集成)构建多租户SaaS应用程序使用Next.js(后端集成)构建多租户SaaS应用程序Apr 11, 2025 am 08:23 AM

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务

如何使用Next.js(前端集成)构建多租户SaaS应用程序如何使用Next.js(前端集成)构建多租户SaaS应用程序Apr 11, 2025 am 08:22 AM

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

JavaScript:探索网络语言的多功能性JavaScript:探索网络语言的多功能性Apr 11, 2025 am 12:01 AM

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。

JavaScript的演变:当前的趋势和未来前景JavaScript的演变:当前的趋势和未来前景Apr 10, 2025 am 09:33 AM

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版