JavaScript(函数,作用域和闭包)(下)

简介: JavaScript(函数,作用域和闭包)

三,变量的作用域

根据变量作用范围不同,分类

局部变量

在函数内部声明的变量(必须使用var)

只能在函数内部访问它

可以在不同的函数中使用名称相同的局部变量

全局变量

在函数外声明的变量

网页的所有脚本和函数都能访问它

    var x = 10;
    function f1(){
        var y = 5;
        console.log(x); // 10
        console.log(y); // 5
    }
    f1();
    console.log(x); // 10
    console.log(y); // y is not defined

局部变量与全局变量的区别

区别 局部变量 全局变量
作用域 仅作用在函数中 作用在整个脚本
声明位置 函数中 使用之前的任何位置
生存期 在函数运行以后被删除 在页面关闭后被删除

3.1,隐式全局变量

如果变量声明时,没有使用关键字var,则被称为隐式全局变量

示例

var a1 = 1;  //全局变量
a2 = 2;        //隐式全局变量

如果在函数内部声明变量时,没有使用关键字var,则也是隐式全局变量

    function f1(){
        var num = 100;
    }
    f1();
    console.log(num); // 函数会报错

    function f1(){
        num = 100;
    }
    f1();
    console.log(num);

与解析:
1.会把全局变量的“声明”提前
2.提前声明函数,但是函数内部的代码是不执行的
局部变量:必须在函数内部使用var/let声明,如果不使用,则称为隐式全局变量
隐式全局变量:只有在执行后使用,
全局变量和局部变量可以重名,使用就近原则

四,作用域与块级作用域

作用域

是变量与函数的可访问范围

控制着变量与函数的可见性和生命周期

块级作用域

由花括号“ { } ”限定

所有的变量都定义在花括号内

变量从定义开始到花括号结束的范围内可以使用

使用场景

正常带有大括号的语句

条件语句

循环语句

函数

    正常带有大括号的语句
    {
        var num = 10;
    }
    console.log(num); // 10
    // 条件语句
    if(true){
        var num = 20;
    }
    console.log(num); // 20
    // 循环语句
    for(var i=0;i<5; i++){
        var num = 30;
    }
    console.log(num); // 30
    // 函数
    function f1(){
        var num  = 50;
    }
    f1();
    console.log(num); // num is not defined

五,作用域链

Scope Chain

是JavaScript内部一种变量、函数查找机制

决定了变量和函数的作用范围

当执行函数时,先从函数内部寻找局部变量

如果内部找不到,则向创建函数的作用域寻找,依次向上

如果最终没有找到,通常会报错

    var num = 10; // <script>里定义的变量,是0级作用域
    function f1(){
        var num = 20; // 1级作用域
        function f2(){
            var num = 30; // 2级作用域
            function f3(){
                var num = 50; // 3级作用域
                console.log(num);
            }
            f3();
        }
        f2();
    }
    f1()

六,闭包

如何在函数外部读取函数内的局部变量呢?

闭包(closure)

能够读取其他函数内部变量的函数

是将函数内部和函数外部链接起来的桥梁

实现步骤

在一个函数的内部,再定义一个函数

把内部的函数作为返回值

特性

函数嵌套

内部函数可以访问外部函数的变量

参数和变量不会被回收

最典型的应用

实现回调函数

    // 1.在函数内部定义一个函数
    // 2. 把内部函数作为外部函数的返回值
    // 原理:利用了内部函数可以调用外部函数的变量
    function f1(){
        var num = 20;
        function f2(){
            alert(num);
        }
        return f2;
    }
    var result = f1();
    result();

作用

可以读取函数内部的变量

让这些变量的值始终保存在内存中

缺点

在父函数外部,可以改变父函数内部变量的值

常驻内存,会增大内存使用量,使用不当很容易造成内存泄露

目录
打赏
0
0
0
0
19
分享
相关文章
JS进阶教程:递归函数原理与篇例解析
通过对这些代码示例的学习,我们已经了解了递归的原理以及递归在JS中的应用方法。递归虽然有着理论升华,但弄清它的核心思想并不难。举个随手可见的例子,火影鸣人做的影分身,你看到的都是同一个鸣人,但他们的行为却能在全局产生影响,这不就是递归吗?雾里看花,透过其间你或许已经深入了递归的魅力之中。
80 19
JavaScript闭包深入剖析:性能剖析与优化技巧
JavaScript 闭包是强大而灵活的特性,广泛应用于数据封装、函数柯里化和事件处理等场景。闭包通过保存外部作用域的变量,实现了私有变量和方法的创建,提升了代码的安全性和可维护性。然而,闭包也可能带来性能问题,如内存泄漏和执行效率下降。为优化闭包性能,建议采取以下策略:及时解除对不再使用的闭包变量的引用,减少闭包的创建次数,使用 WeakMap 管理弱引用,以及优化闭包结构以减少作用域链查找的开销。在实际开发中,无论是 Web 前端还是 Node.js 后端,这些优化措施都能显著提升程序的性能和稳定性。
172 70
当面试官再问我JS闭包时,我能答出来的都在这里了。
闭包(Closure)是前端面试中的高频考点,广泛应用于函数式编程中。它不仅指函数内部定义的函数,还涉及内存管理、作用域链和垃圾回收机制。闭包可以让函数访问其外部作用域的变量,但也可能引发内存泄漏等问题。通过合理使用闭包,可以实现模块化、高阶函数和回调函数等应用场景。然而,滥用闭包可能导致代码复杂度增加、调试困难以及潜在的性能问题。为了避免这些问题,开发时应谨慎处理闭包,避免不必要的嵌套,并及时清理不再使用的变量和监听器。
203 16
当面试官再问我JS闭包时,我能答出来的都在这里了。
JavaWeb JavaScript ③ JS的流程控制和函数
通过本文的详细介绍,您可以深入理解JavaScript的流程控制和函数的使用,进而编写出高效、可维护的代码。
124 32
JavaScript中闭包详解+举例,闭包的各种实践场景:高级技巧与实用指南
闭包是JavaScript中不可或缺的部分,它不仅可以增强代码的可维护性,还能在模块化、回调处理等场景中发挥巨大作用。然而,闭包的强大也意味着需要谨慎使用,避免潜在的性能问题和内存泄漏。通过对闭包原理的深入理解以及在实际项目中的灵活应用,你将能够更加高效地编写出简洁且功能强大的代码。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
柯里化是一种强大的函数式编程技术,它通过将函数分解为单参数形式,实现了灵活性与可复用性的统一。无论是参数复用、延迟执行,还是函数组合,柯里化都为现代编程提供了极大的便利。 从 Redux 的选择器优化到复杂的数据流处理,再到深度嵌套的函数优化,柯里化在实际开发中展现出了非凡的价值。如果你希望编写更简洁、更优雅的代码,柯里化无疑是一个值得深入学习和实践的工具。从简单的实现到复杂的应用,希望这篇博客能为你揭开柯里化的奥秘,助力你的开发之旅! 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等