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

怎么使用作用域与作用域链

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

怎么使用作用域与作用域链

这篇文章主要讲解了“怎么使用作用域与作用域链”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用作用域与作用域链”吧!

一、作用域

如果说执行上下文是代码的执行环境,那么作用域就是执行环境中的一套执行规则,既然是规则,JavaScript  引擎执行代码时要遵守这套规则,同时开发人员在写代码时,同样也要遵守这套规则。

1、什么是作用域

我们先来看这样一个例子:

function foo () {   var bar = 'xiaolu' } foo() console.log(bar)

上述的运行结果很明显,控制台会报错 bar is not  defined,我们可以通过这个小例子就可以发现在函数外部访问函数内部声明的变量是不可访问的,这背后的原因就是 JavaScript  作用域存在导致的结果。

2、什么是词法环境

说到作用域,那什么是作用域?我们先来认识一下这位老朋友词法环境。

ECMAScript 规范中对词法环境的描述如下:词法环境是用来定义基于词法嵌套结构的 ECMAScript  代码内的标识符与变量值和函数值之间的关联关系的一种规范类型。

说的直白一点,词法环境就是一套规范和规则,它用来规定某些函数和变量的可访问范围等,我们也称词法环境为「词法作用域」。

既然词法作用域是一套约定好的规则,那么词法作用域的作用范围是开发人员在写代码的时候就已经是确定了的。

当代码执行的时候, JavaScript 引擎就会根据这套规范通过标识符名称来查找相对应的变量和函数。

好吧,最后给它做个总结性的定义。

作用域:作用域是一套约定好的规范和规则,它用来规定某些函数和变量的可访问性等。

二、作用域链

作用域我们弄明白了,我们再来看作用域链。作用域链和作用域却大不相同,咱们分别从「执行栈层面」和「代码层面」来体验一下什么是作用域链。

var name = "xiaolu"; function fn () {   console.log(name);   function getName(){     console.log(name);   }   getName(); } fn();

执行栈中的作用域链示意图:

图片

该示意图为上述代码的执行情况,在上述示意图中,不同的色块缩进形成的可访问链就是我们所说的作用域链。

虽然上述示意图是抽象出来的,如果我们在代码层面来理解作用域链,又是如何实现的呢?

在上一篇中分享到,每当创建一个新的执行上下文时,都会创建一个「变量对象」用于存放当前执行上下文中的变量和函数。(记住:这个变量对象很重要)

如果我们把这些执行上下文的「变量对象」关联起来,就形成了一条链,我们把这条链的实现称为「作用域链」。

图片

上述代码的执行结果是打印输出:

1var name = "xiaolu";

2function fn () {

3 console.log(name);

4 function getName(){

5 console.log(name);

6 }

7 getName();

8}

9fn();

当内部的 getName 执行时 JavaScript 引擎就在 getName 作用域内查找变量  name,发现并没有,就会沿着上图中的作用域链往上层寻找,在 fn 的作用域中也没有发现 name  变量,然后继续沿着作用域链往上层的寻找,直到全局作用域中,发现存在变量 name,然后输出 name 的值。

感谢各位的阅读,以上就是“怎么使用作用域与作用域链”的内容了,经过本文的学习后,相信大家对怎么使用作用域与作用域链这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

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

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

怎么使用作用域与作用域链

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

下载Word文档

猜你喜欢

JavaScript作用域与作用域链使用重点讲解

当代码在一个环境中执行时,会创建变量对象的一个作用域链,作用域链的用途是保证对执行环境有权访问的所有变量和函数的有序访问,下面这篇文章主要给大家介绍了关于JavaScript作用域与作用域链的相关资料,需要的朋友可以参考下
2022-11-13

js作用域链怎么使用

这篇文章主要介绍js作用域链怎么使用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!说明1、只要是代码,至少有一个作用域。写在函数内部的局部作用域。2、如果函数中有函数,在这个功能域中可以诞生另一个功能域。3、根据内部
2023-06-20

js作用域及作用域链工作引擎怎么应用

本文小编为大家详细介绍“js作用域及作用域链工作引擎怎么应用”,内容详细,步骤清晰,细节处理妥当,希望这篇“js作用域及作用域链工作引擎怎么应用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、作用域(scope
2023-07-02

JavaScript作用域链是什么及怎么使用

这篇文章主要介绍了JavaScript作用域链是什么及怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript作用域链是什么及怎么使用文章都会有所收获,下面我们一起来看看吧。1. 作用域是什么
2023-07-04

如何分析javascript作用域和作用域链

如何分析javascript作用域和作用域链,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、javascript的作用域1、全局作用域1、最外层函数和最外层函
2023-06-28

JS作用域作用链及this使用原理详解

这篇文章主要为大家介绍了JS作用域作用链及this使用原理详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

python作用域怎么用

小编给大家分享一下python作用域怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!作用域变量的作用域决定了在哪一部分程序可以访问哪个特定的变量名称。Pyth
2023-06-17

编程热搜

  • 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动态编译

目录