JavaScript的作用域

本文深入探讨JavaScript中作用域的概念,包括顶层作用域、代码块作用域、子作用域的访问规则及变量覆盖现象,通过实例解析作用域的层次结构和变量的可见性。

在JavaScript中作用域占很重要的一部分,我们总是看到for,if,function后面跟着{},所有{}包起来的代码称之

为代码块。每个代码块都有自己的作用域,作用域决定了变量能否被访问(不论修改变量还是读取变量)。作用域就像在做数学题时有时要求xy的取值范围。

[1]在最上层中没有任何{}的作用域为顶层作用域,声明变量是哪里都可以访问的。
var numbers = {a : 2, b : 3};//顶层作用域
function get_sum(a, b){//可以访问
    var result = a + b;//可以访问
    return result;
}
var sum = get_sum(numbers.a, numbers.b);//可以访问
console.log(sum);
 [2]代码块是有层级的,在一个代码块里写的新的代码块,后者是前者的子作用域。
if(true){
    //相对于下面的代码块的父作用域
    var x = 5;
    if(x > 0){
        //子作用域
    }
}
 [3]子作用域可以访问父作用域的变量,而父作用域无法访问子作用域的变量。
if(true){//父作用域
    var x = 5;
    if(x > 0){//子作用域
        var y = "a";
        console.log(x); //可以访问
        x = 6; //也可以访问
    }
    console.log(y); //不应该在这里再访问了。
}
注:在js中作用域 for,if是可以打印出console.log(y);除了function,父作用域是可以全部访问的。
 [4]作用域的父级的父级作用域的变量,该作用域里也可以访问,甚至无穷多级父的作用域里的变量都

可以被访问,这种无穷多级的父,被称之为祖先。

if(true){
    var x = 5;
    if(x > 0){
        console.log(x); //可以访问
        for(var i = 0; i < x; i++){
            console.log(x); //也可以访问
        }
    }
}

[5]顶层作用域是所有作用域的祖先

var x = 5;
function a(x){
    if(x > 0){
        x++;
    }
    console.log(x);//这时访问x不是父作用域的x,而是参数x
}
a(1);
console.log(x);

 当子作用域有变量与父作用域重名时,在子作用域里只能访问到子作用域的变量,称之为覆盖。覆盖并不会

改变父作用域的变量。

作用域(Scope)是指在代码中定义变量时,这些变量在哪里以及在哪些地方可以被访问,控制着变量的可见性和生命周期。在 JavaScript 中,作用域的类型主要由函数定义和代码块定义来决定[^2]。以下是 JavaScript 作用域的类型介绍: - **全局作用域**:在 `<script>` 标签中或者 js 脚本中定义的变量属于全局作用域。全局作用域中的变量可以在代码的任何地方被访问[^3]。 ```javascript var globalVar = 'I am a global variable'; function testGlobal() { console.log(globalVar); // 可以访问全局变量 } testGlobal(); ``` - **局部作用域**:在函数中定义的变量属于局部作用域,使用 `var` 关键字声明,这些变量只能在函数内部被访问,函数外部无法直接访问这些变量[^3]。 ```javascript function testLocal() { var localVar = 'I am a local variable'; console.log(localVar); // 可以在函数内部访问局部变量 } testLocal(); console.log(localVar); // 报错,无法在函数外部访问局部变量 ``` - **块作用域**:ES6 中在 `{}` 代码块中使用 `let` 或 `const` 定义的常量、变量属于块作用域;而 ES6 之前使用 `var` 关键字在 `{}` 代码块中定义的变量,取决于代码块位置,代码块在全局作用域则该变量属于全局作用域,代码块在局部作用域则该变量属于局部作用域[^3]。 ```javascript // 使用 let 声明,具有块级作用域 if (true) { let blockVar = 'I am a block variable'; console.log(blockVar); // 可以在代码块内部访问 } console.log(blockVar); // 报错,无法在代码块外部访问 // 使用 var 声明,没有块级作用域 if (true) { var oldStyleVar = 'I am declared with var'; } console.log(oldStyleVar); // 可以访问 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值