博客
关于我
JavaScript(五):变量的作用域
阅读量:769 次
发布时间:2019-03-23

本文共 1495 字,大约阅读时间需要 4 分钟。

JavaScript 变量作用域解析

在 JavaScript 的变量管理中,变量可以分为全局变量和局部变量两类,每种变量的作用域也不同。本文将详细讲解两者及其作用域的特点。

全局变量与局部变量的分类

JavaScript 中的变量分为两大类:

  • 全局变量:定义在函数外部的变量,其作用域范围覆盖整个脚本文件。
  • 局部变量:在函数内部定义的变量,其作用域仅限于该函数内部,外部无法访问。
  • 局部变量的作用域

    局部变量的定义和使用都具有特定的作用域限制。下面的代码示例说明了这一点:

    function fn() {
    var a = 5;
    document.write(a); // 输出:5
    }
    function fn2() {
    document(a); // 输出:undefined
    }
    fn();
    fn2();

    运行结果可以看出,adocument(a) 分别输出 5undefined,这体现了函数内部和外部变量的访问控制机制。

    全局变量的作用域

    全局变量的定义和修改具有更大的灵活性,例如:

    var number; // 全局变量
    function fn() {
    number = 5;
    document.write("number的值是:" + number + "
    ");
    }
    function fn2() {
    ++number;
    document.write("number的值是:" + number + "
    ");
    }
    fn();
    fn2();

    在上述代码中,number 在两个函数中都被修改,结果显示了全局变量的单独性和可修改性。

    特殊情形:就近原则

    在函数内部,如果你尝试访问与全局变量相同的名称,JavaScript 会采用就近原则,即优先访问局部变量:

    var number; // 全局变量
    function fn() {
    var number = "我是局部变量";
    document.write("number的值是:" + number + "
    "); // 输出:我是局部变量
    }
    function fn2() {
    number = "我是全局变量"; // 直接修改全局变量
    document.write("number的值是:" + number + "
    "); // 输出:我是全局变量
    }
    fn();
    fn2();

    运行结果可以看出,numberfn() 中输出为局部变量的值,而在 fn2() 中输出为全局变量的值。

    注意事项

  • 即时作用域:未使用 varletconst 关键字定义的变量,会在 window 对象上作为全局变量存在。

    a = 12; // 等价于 window.a = 12
    function fn() {
    b = "我是window对象, 是全局变量";
    }
    fn();
    document.write("a=" + a + "
    ");
    document.write("b=" + b + "
    ");

    输出结果会显示 ab 均为全局变量。

  • 减少全局变量的使用:为了避免代码冲突和维护困难,尽量减少全局变量的使用,建议使用块作用域(letconst)或局部变量。

  • 结果

    以上内容通过实际代码示例,清晰地解释了 JavaScript 中全局变量和局部变量的区别及作用域特点。通过这些知识点,你可以更好地理解 JavaScript 的变量管理方式,合理选择变量的定义和使用方式,以实现代码的高效管理和维护。

    转载地址:http://wfxzk.baihongyu.com/

    你可能感兴趣的文章
    pandas :我如何对堆叠的条形图进行分组?
    查看>>
    pandas :按移位分组和累加和(GroupBy Shift And Cumulative Sum)
    查看>>
    pandas :检测一个DF和另一个DF之间缺失的列
    查看>>
    Pandas-从具有嵌套列表列表的现有列创建动态列时出错
    查看>>
    Pandas-通过对列和索引的值求和来合并两个数据框
    查看>>
    pandas.columns、get_dummies等用法
    查看>>
    pandas.DataFrame.copy(deep=True) 实际上并不创建深拷贝
    查看>>
    pandas.read_csv()的详解-ChatGPT4o作答
    查看>>
    PANDAS.READ_EXCEL()输出‘;溢出错误:日期值超出范围‘;而不存在日期列
    查看>>
    pandas100个骚操作:再见 for 循环!速度提升315倍!
    查看>>
    Pandas:如何根据其他列值的条件对列进行求和?
    查看>>
    Pandas:对给定列求和 DataFrame 行
    查看>>
    Pandas、Matplotlib、Pyecharts数据分析实践
    查看>>
    Pandas中文官档 ~ 基础用法1
    查看>>
    Pandas中文官档~基础用法2
    查看>>
    Pandas中文官档~基础用法5
    查看>>
    Pandas中文官档~基础用法6
    查看>>
    Pandas中的GROUP BY AND SUM不丢失列
    查看>>
    Pandas之iloc、loc
    查看>>
    pandas交换两列
    查看>>