zoukankan      html  css  js  c++  java
  • JavaScript中的匿名函数及函数的闭包

    1、匿名函数

    第一种方式:

    var double = function(x) { return 2* x; }
    

    注意“=”右边的函数就是一个匿名函数,创造完毕函数后,又将该函数赋给了变量square。

    第二种方式:

    (function(x, y){
        alert(x + y);  
    })(2, 3);
    

    这里创建了一个匿名函数(在第一个括号内),第二个括号用于调用该匿名函数,并传入参数。

    2、闭包

    闭包的英文单词是closure,这是JavaScript中非常重要的一部分知识,因为使用闭包可以大大减少我们的代码量,使我们的代码看上去更加清晰等等,总之功能十分强大。

    闭包的含义:闭包说白了就是函数的嵌套,内层的函数可以使用外层函数的所有变量,即使外层函数已经执行完毕(这点涉及JavaScript作用域链)。

    function checkClosure(){
        var str = 'rain-man';
        setTimeout(
            function(){ alert(str); } //这是一个匿名函数
        , 2000);
    }
    checkClosure();
    

    执行过程:checkClosure函数的执行是瞬间的(也许用时只是0.00001毫秒),在checkClosure的函数体内创建了一个变量str,在checkClosure执行完毕之后str并没有被释放,这是因为setTimeout内的匿名函数存在这对str的引用。待到2秒后函数体内的匿名函数被执行完毕,str才被释放。

  • 相关阅读:
    快速排序算法
    HTTP中的重定向和请求转发的区别
    单链表的逆置(头插法和就地逆置)
    水仙花数学习
    构建n位元的格雷码
    算法学习day01 栈和队列
    数据结构学习总结 线性表之双向链表
    设计模式
    Nginx 初步认识
    数据结构学习总结(2) 线性表之单链表
  • 原文地址:https://www.cnblogs.com/brant/p/5582393.html
Copyright © 2011-2022 走看看