1、js - 面试 - 作用域

文章详细介绍了JavaScript中的变量作用域,包括全局作用域(在<script>标签或.js文件中声明的变量)、函数作用域(函数内部的变量)和块级作用域(由let/const声明的变量)。强调了局部作用域的限制和重要性,以及为何避免过多全局变量以防止命名冲突和优化性能。
摘要由CSDN通过智能技术生成
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

</body>

</html>
<script>

    // 官方说法:全局作用域、函数作用域、块级作用域、模块作用域
    // 通俗说法:局部作用域分为函数作用域和块级作用域
    // 外部无法使用局部作用域的变量:因为局部用完了,变量会被释放掉

    // 1、全局作用域
    // 全局作用域:<script>标签内部、.js文件
    // 全局作用域声明的变量其他作用域可以使用
    // 注意⚠️:(1)在函数中未使用任何关键字声明的变量是全局变量
    // 注意⚠️:(2)为window对象动态添加的属性是全局变量
    // 尽可能少声明全局变量,减少变量命名污染

    // 2、函数作用域
    // 在函数内部声明的变量只能在函数内部访问,外部无法访问
    // 函数的形参可以看作是函数的局部变量
    function func(num) {
        // 形参num相当于局部变量
        console.log("num-->", num);
        var test = "hello";
    }
    func(1);
    // 外部无法使用函数内部的变量
    console.log("test-->", test); // Uncaught ReferenceError: test is not defined

    // 3、块级作用域
    // 使用{}包裹的代码称为代码块: for  if  while  {}...  这些都会形成块级作用域
    // let/const声明会产生块级作用域,推荐使用let/const
    for (let i = 0; i < 3; i++) {
        console.log("i1-->", i);
    }
    // 外部无法使用块级作用域内部的变量
    console.log("i2-->", i); // Uncaught ReferenceError: i is not defined

    // 为什么要有局部变量,不全部搞成全局变量:1、变量命名污染  2、释放资源,提高性能
    // 例如:函数调用完,函数就执行结束了,这就意味着函数里面的变量没用了,函数里的变量被释放了,函数这块的空间就被释放出来了

</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值