函数类型以及闭包

2017-07-20  本文已影响0人  lucent刘

函数的类型可以是直接声明一个函数,或者匿名来声明一个函数。普通函数和匿名函数基本来说是相同的,但是普通函数会自动把函数名提到作用域的最前面。

普通函数

function a(){

};

匿名函数

var a = function(){

};

没有名字的函数:function( ){ };
使用function关键字声明一个函数,但未给函数命名,就叫做匿名函数。立即执行函数(function(){...})()内部定义的变量不会和外部的变量发生冲突。

闭包

闭包的含义:闭包也就是说函数的嵌套,可使内部访问外部作用域。内存常驻,变量持久化。

function aaa(){
    var a=5;
    function bbb(){
        alert(a);
    }
    bbb{};
}

这就是一个简单的闭包,也是对闭包最简单的理解。当然闭包还有更深入的理解,比如执行环境、活动对象以及作用域等等。只是希望大家能对此有一个基本的了解。

闭包的缺点: 函数执行完毕之后,会自动销毁,没有立即销毁的函数,会产生内存泄漏。

在使用中最好不要刻意的使用闭包。

习题

function fun(n,o){
    console.log(o);
    return{
        fun:function(m){
            return fun(m,n);
        }
    };
}
var a=fun(0);a.fun(1);a.fun(2);a.fun(3);
var b=fun(0).fun(1).fun(2).fun(3);
var c=fun(0).fun(1);c.fun(2);c.fun(3);

var a 的答案为undefined,0,0,0

fun(0)调用了第一层fun函数,n=1,o则为undefined;fun(1)时m=1,fun闭包了外层函数的n,第一次调用的n=0,即m=1,并在内部调用了第一层fun函数fun(1,0),所以o为0;fun(2)时m=2,但还是调用了a.fun,所以内部还是调用了第一层的fun(2,0),所以o为0;fun(3)同理,依然为0;

var b 的答案为undefined,0,1,2

fun(0)还是调用了第一层fun函数,o依然为undefined;fun(1)时m=1,fun闭包了外部函数的n,即m=1,n=0,o则为0;fun(2)m=2 ,此时当前的fun函数不是第一次执行的返回对象,而是第二次执行的返回对象。而在第二次执行第一层fun函数时(1,0)所以n=1,o=0,返回时闭包了第二次的n,在第三次调用第三层fun函数时m=2,n=1,即调用第一层fun函数fun(2,1),所以o为1;fun(3) 时m=3,闭包了第三次调用的n,同理,最终调用第一层fun函数为fun(3,2),所以o为2;

var c 的答案为undefined,0,1,1

fun(0)的o依然为undefined;fun(1) 时m为1,此时fun闭包了外层函数的n,也就是第一次调用的n=0,即m=1,n=0,并在内部调用第一层fun函数fun(1,0),所以o为0;fun(2)时m为2,此时fun闭包的是第二次调用的n=1,即m=2,n=1,并在内部调用第一层fun函数fun(2,1),所以o为1;fun(3)同理,但依然调用第二次的返回值,最终调用第一层fun函数fun(3,1),所以o为1;

上一篇下一篇

猜你喜欢

热点阅读