JavaScript复习记录(5)—作用域

作用域(scope)是一个变量、函数或对象的可访问范围。以下是JavaScript中作用域的几种类型和相关概念:

1. 全局作用域(Global Scope)

任何在全局作用域中声明的变量或函数都可以在代码的任何地方访问。全局变量在浏览器环境中会成为window对象的属性。

javascript 复制代码
var global = "global variable";

function globalFunction() {
    console.log(global); // global varable
}

2. 函数作用域(Function Scope)

在函数内部声明的变量只能在该函数内部访问。使用var声明的变量具有函数作用域。

javascript 复制代码
function functionScope() {
    var localVar = "local variable";
    console.log(localVar);
}

console.log(localVar); // Error: localVar is not defined

3. 块级作用域(Block Scope)

块级作用域由花括号{}包围的代码块定义。在letconst引入之前,JavaScript没有块级作用域。letconst允许我们在块级作用域内声明变量。

javascript 复制代码
{
    let blockVar = "I'm a block-scoped variable";
    console.log(blockVar);
}

console.log(blockVar); // Error: blockVar is not defined

4. 词法作用域(Lexical Scope)

JavaScript采用词法作用域,也称为静态作用域。这意味着函数的作用域在定义时就已经确定,而不是在调用时确定。

javascript 复制代码
function outerFunction() {
    var outerVar = "I'm outside!";

    function innerFunction() {
        console.log(outerVar); // 可以访问outerFunction中的变量
    }

    innerFunction();
}

outerFunction();

5. 闭包(Closure)

闭包是指有权访问另一个函数作用域中的变量的函数。即使外部函数已经执行完毕,内部函数仍然可以访问外部函数的变量。

javascript 复制代码
function outerFunction() {
    var outerVar = "I'm outside!";

    return function innerFunction() {
        console.log(outerVar);
    };
}

var closureFunction = outerFunction();
closureFunction(); // "I'm outside!"

6. 模块作用域(Module Scope)

在ES6中,引入了模块,模块中的变量默认具有模块作用域。一个模块的变量在其他模块中是不可见的,除非明确导出并导入。

javascript 复制代码
// module1.js
export const moduleVar = "I'm a module-scoped variable";

// module2.js
import { moduleVar } from './module1.js';
console.log(moduleVar);

作用域链(Scope Chain)

作用域链是指在当前作用域中无法找到某个变量时,JavaScript会沿着作用域链向上查找,直到找到该变量或到达全局作用域。

javascript 复制代码
var globalVar = "Global";

function outerFunction() {
    var outerVar = "Outer";

    function innerFunction() {
        var innerVar = "Inner";
        console.log(innerVar); // Inner
        console.log(outerVar); // Outer
        console.log(globalVar); // Global
    }

    innerFunction();
}

outerFunction();
相关推荐
惊鸿一博1 分钟前
java_网络服务相关_gateway_nacos_feign区别联系
java·开发语言·gateway
Bruce_Liuxiaowei6 分钟前
深入理解PHP安全漏洞:文件包含与SSRF攻击全解析
开发语言·网络安全·php
成工小白6 分钟前
【C++ 】智能指针:内存管理的 “自动导航仪”
开发语言·c++·智能指针
sc写算法9 分钟前
基于nlohmann/json 实现 从C++对象转换成JSON数据格式
开发语言·c++·json
Andrew_Xzw14 分钟前
数据结构与算法(快速基础C++版)
开发语言·数据结构·c++·python·深度学习·算法
库库的里昂15 分钟前
【C++从练气到飞升】03---构造函数和析构函数
开发语言·c++
多多*2 小时前
LUA+Reids实现库存秒杀预扣减 记录流水 以及自己的思考
linux·开发语言·redis·python·bootstrap·lua
Dontla3 小时前
为什么React列表项需要key?(React key)(稳定的唯一标识key有助于React虚拟DOM优化重绘大型列表)
javascript·react.js·ecmascript
Wish3D3 小时前
阿里云OSS 上传文件 Python版本
开发语言·python·阿里云
凤年徐3 小时前
【数据结构初阶】单链表
c语言·开发语言·数据结构·c++·经验分享·笔记·链表