0

0

了解 JavaScript 中的作用域和作用域链

霞舞

霞舞

发布时间:2024-11-09 12:36:41

|

884人浏览过

|

来源于dev.to

转载

了解 javascript 中的作用域和作用域链

javascript 开发人员经常会遇到作用域、作用域链、词法环境和不同类型的作用域(全局作用域、函数作用域和局部作用域)等术语。这些概念对于理解变量和函数的行为方式、它们的可访问性以及 javascript 在执行代码时如何找到它们至关重要。在本博客中,我们将分解这些主题,以帮助您掌握 javascript 中的作用域和作用域链。

1。什么是范围?

在 javascript 中,作用域定义了变量和函数的可访问性或可见性。它决定变量在哪里可用以及在哪里不可用。例如,在一个函数中定义的变量可能无法在另一函数中或全局访问。 javascript 有几种类型的作用域,您应该注意:

  • 全球范围
  • 功能范围
  • 块/本地范围

了解这些不同类型的作用域可以帮助您编写高效且无错误的代码。

立即学习Java免费学习笔记(深入)”;

2。词汇环境

在深入研究不同类型的范围之前,了解词法环境非常重要。每次运行 javascript 代码时,它都会创建一个词法环境来管理代码特定部分中定义的变量和函数。词汇环境包括:

  • 环境记录 – 存储范围内的变量和函数。
  • 对外部环境的引用 – 保持与外部词法环境(通常称为父环境)的链接,这允许范围链。

javascript 使用词法环境根据代码编写位置(不一定是执行位置)来确定变量的可访问性。这个过程称为词法作用域。

3。 javascript 中的作用域类型

a) 全球范围

全局范围意味着变量或函数是在最外层上下文中定义的(即不在函数或块内)。在全局范围内定义的变量可以在代码中的任何位置访问。

let globalvar = "i'm global!";

function printglobalvar() {
    console.log(globalvar); // accessible here
}

printglobalvar(); // output: i'm global
console.log(globalvar); // also accessible here

在此示例中,globalvar 是在全局范围内定义的,使其可以在 printglobalvar 函数内部和外部访问。

b) 功能范围

javascript 具有函数作用域,这意味着在函数内部使用 var、let 或 const 声明的变量在该函数外部无法访问。函数创建自己的作用域并限制其中定义的变量。

中解商务通
中解商务通

实时捕捉 一旦访问者打开您的网站,系统会立即显示,这时您就可以查看用户的信息,如:来自搜索引擎关键词、友情链接或直接访问;访问者的IP地址,所在地区,正在访问哪个网页;以及访问者使用的操作系统、浏览器、显示器屏幕分辨率颜色深度等。 主动出击 变被动为主动,可以主动邀请访问者进行洽谈勾通,帮助客户深入了解您的企业和产品,同时获得对方的采购意向、联系方式等信息。 互动交流 主动销售和在线客服合二为一,

下载
function myfunction() {
    let localvar = "i'm local!";
    console.log(localvar); // output: i'm local!
}

myfunction();
console.log(localvar); // error: localvar is not defined

这里,localvar 是在 myfunction 内部定义的,无法在其外部访问,展示了函数作用域。

c) 块作用域(局部作用域)

块作用域,或局部作用域,将变量的可见性限制在定义它们的块中。在块 ({}) 内用 let 或 const 声明的变量只能在该块内访问。另一方面,var 不遵循块作用域,而是遵循函数作用域。

if (true) {
    let blockvar = "i'm block-scoped!";
    console.log(blockvar); // output: i'm block-scoped!
}

console.log(blockvar); // error: blockvar is not defined

在这种情况下,blockvar 只能在 if 块内访问,用 let 演示块作用域。在处理循环和条件时,这种行为至关重要。

4。范围链

作用域链是 javascript 的机制,它通过在多个作用域中向上移动来查找变量值,直到找到变量或到达全局作用域。此过程通过词法作用域进行,这意味着代码的结构(编写函数的位置)决定首先搜索哪个作用域。

let globalVar = "I'm global!";

function outerFunction() {
    let outerVar = "I'm outer!";

    function innerFunction() {
        let innerVar = "I'm inner!";

        console.log(globalVar); // Accessible due to scope chaining
        console.log(outerVar);  // Accessible due to scope chaining
        console.log(innerVar);  // Directly accessible
    }

    innerFunction();
}

outerFunction();

在上面的例子中:

  1. 由于作用域链,innerfunction 可以访问innervar、outervar 和globalvar。
  2. javascript 首先检查每个变量的局部作用域 (innerfunction),然后检查封闭函数的作用域 (outerfunction),最后检查全局作用域。

如果在任何这些作用域中都找不到变量,javascript 会抛出 referenceerror。

5。范围如何影响您的代码

理解和利用 javascript 中的作用域链和词法环境可以使您的代码更加高效和安全。以下是一些最佳实践:

  • 最小化全局变量:太多的全局变量可能会导致意外错误,尤其是在处理多个脚本时。
  • 对变量使用块作用域:优先使用 let 和 const 而不是 var 来利用块作用域并避免意外的变量泄漏。
  • 在闭包中利用词法作用域:保留对其直接作用域之外的变量的访问权限的函数称为闭包。闭包对于创建模块化和私有代码非常强大。

结论

javascript 中的作用域和作用域链对于控制代码中的变量可访问性和内存使用至关重要。通过了解全局作用域、函数作用域和块作用域的细微差别以及词法环境的概念,您可以编写更有效且无错误的代码。使用这些原则明智地管理变量并创建更干净、更模块化的 javascript 应用程序!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

779

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

531

2023.09.20

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

81

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

96

2025.09.18

go语言闭包相关教程大全
go语言闭包相关教程大全

本专题整合了go语言闭包相关数据,阅读专题下面的文章了解更多相关内容。

137

2025.07.29

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

8

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

8

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

6

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

1

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.6万人学习

10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号