JS 作用域与作用域链详解

2023-12-09前端开发
2

当我们使用 JavaScript 编写代码时,经常会遇到变量作用域的问题,这个时候就需要了解 JavaScript 的作用域与作用域链。了解 JavaScript 的作用域与作用域链,可以帮助我们更好地理解 JavaScript 代码运行的流程,从而提高编程效率和代码质量。

一、作用域

1.1 什么是作用域

作用域是指变量和函数的可访问范围。JavaScript 程序中,每个变量和函数都有自己的作用域,这个作用域包含了这个变量或函数可以被访问的代码段。

1.2 JavaScript 的作用域类型

JavaScript 中的作用域分为两种类型:全局作用域和局部作用域。

1.2.1 全局作用域

全局作用域是指在整个 JavaScript 程序中都可以访问的变量和函数。在 JavaScript 中,如果一个变量或函数没有在某个特定的作用域中声明,那么它就被默认归为全局作用域。

1.2.2 局部作用域

局部作用域是指在一个函数中声明的变量或函数只能在该函数内部被访问。它们无法在函数外部访问。

1.3 变量的作用域

变量的作用域是指这个变量可以被访问的代码范围。在 JavaScript 中,变量的作用域是由它在代码中声明的位置所决定的。变量在声明的作用域外无法被访问。

下面是一个示例,展示了 JavaScript 中变量的作用域:

var globalVariable = "Global Variable";

function testScope() {
  var localVariable = "Local Variable";
  console.log(globalVariable); // 输出 "Global Variable"
  console.log(localVariable); // 输出 "Local Variable"
}

testScope();
console.log(globalVariable); // 输出 "Global Variable"
console.log(localVariable); // 报错,因为 localVariable 是在函数内部声明的,函数外部无法访问

这个示例中定义了一个全局变量 globalVariable,一个局部变量 localVariable。在函数 testScope() 中,我们可以访问到全局变量和局部变量,而在函数外部只能访问到全局变量。当我们尝试在函数外部访问局部变量 localVariable 时,这段代码会报错,因为在函数外部无法访问变量 localVariable。

二、作用域链

2.1 什么是作用域链

作用域链是 JavaScript 中非常重要的概念,它是决定变量和函数访问权限的机制。在 JavaScript 中,每个作用域都有一个链,这个链指向了外部作用域,形成了一个作用域链。当一个变量或函数需要被访问时,JavaScript 引擎会先在当前作用域中查找,如果没有找到,则逐级向外部作用域查找,直到找到为止。

2.2 作用域链的构成

作用域链的构成由当前作用域和父级作用域构成,每个作用域都有一个指向其父级作用域的指针。

下面的示例展示了一个简单的作用域链:

function func1() {
  var a = 1;
  function func2() {
    var b = 2;
    console.log(a);
    console.log(b);
  }
  func2();
}

func1();

在这个示例中,当函数 func2() 被调用时,它需要访问变量 a 和 b。因为变量 a 是定义在 func1() 中,而变量 b 是定义在 func2() 中,这些变量需要通过作用域链来访问。当 func2() 访问变量 a 时,它首先会在自己的作用域中查找是否有定义过的变量 a,如果找到了,就使用这个变量。如果没有找到,则会沿着作用域链逐级向外寻找,直到找到为止。

2.3 作用域链的变化

作用域链的变化是由执行上下文决定的。JavaScript 中的执行上下文是描述执行环境的数据结构,它定义了变量和函数的可访问性以及当前代码的执行状态。

下面的示例展示了当函数 func2() 被调用时,作用域链的变化:

function func1() {
  var a = 1;
  function func2() {
    var b = 2;
    console.log(a);
    console.log(b);
  }
  func2();
}

func1();

当函数 func1() 被调用时,它会创建一个新的执行上下文。在这个执行上下文中,变量 a 和函数 func2() 被定义并保存在作用域链中。当函数 func2() 被调用时,它也会创建一个新的执行上下文。在这个执行上下文中,变量 b 被定义并保存在作用域链中。

总结

以上就是 JavaScript 作用域和作用域链的详细讲解,了解 JavaScript 的作用域和作用域链可以帮助我们编写更加规范高效的代码,避免出现不必要的错误。

The End

相关推荐

layui实现图片上传成功后回显点击放大图片功能
layui实现图片上传成功后回显点击放大图片功能,html代码部分: !-- html代码--div class="layui-form-item" label class="layui-form-label"上传图片/label div class="layui-input-block" button type="button" class="layui-btn" id="license-auth-letter-...
2025-09-06 前端开发
202

Layui实现数据表格中鼠标悬停图片放大离开时恢复原图
Layui实现数据表格中鼠标悬停图片放大离开时恢复原图的效果,最终效果如下图所示: 实现代码如下,在done函数中调用hoverOpenImg方法 var tableIns = window.demoTable = table .render({ elem : '#idTest', id : 'idTest', url : '/postData', //width : 150...
2025-09-04 前端开发
112

layui点击文本输入框调起弹出选择框并选择内容的两种方法参考
我们在用到layui时候,需要点击文本输入框调起弹出选择框并选择内容,这个要怎么操作呢?以下两种方法可以参考: 1、点击名称,弹出信息弹框,选择表格中的某一行,实现效果如下: html页面代码 !--计量器具弹出层-- div id="equipment" lay-filter="equipmen...
2025-09-02 前端开发
167

网站部署https后百度地图不显示问题
https的网站如果引用百度地图,会出现加载不了的问题,这是因为涉及到跨域问题,网站是https的,但是引用百度地图的是http的,这个要怎么操作呢? 比如我引用的地址:http://api.map.baidu.com/api?v=2.0ak=AK显示 后来看了一下,少了一个s=1字段,加一下s=1...
2025-07-28 前端开发
139

微信小程序实现点击复制功能和手机拨打电话功能
做小程序项目的时候,客户提了一个功能需求优化,就是长按文字需要复制全部内容,因为有的手机支持全选复制,有的手机不支持全选复制。 通过设置系统剪贴板的内容和获取系统剪贴板的内容实现复制功能 html相关代码: van-field value="{{form.contactPhone}}"...
2025-07-02 前端开发
78

js拖拽排序插件Sortable.js如何使用
由于项目功能需要,要实现对table中的行实现拖拽排序功能,找来找去发现Sortable.js能很好的满足这个需求,而且它还是开源的,于是乎就开始学习使用Sortable.js 特点 轻量级但功能强大 移动列表项时有动画 支持触屏设备和大多数浏览器(IE9及以下除外) 支持...
2025-06-12 前端开发
161