闭包

本文深入探讨JavaScript中的闭包概念,包括其定义、如何创建及应用,以及如何利用闭包实现变量保护和状态维护。通过具体代码示例,展示闭包在实际编程中的作用,如防止变量冲突和实现变量累加。

/* function foo(){
var a = 10;
function bar(){ //这个函数叫做闭包
console.log(a);
}
} */

/* function foo(){
    var a = 10;
    return function(){
        console.log(a);
    };
}
//return出来的是一个函数表达式,可以在后面接小括号直接调用
foo()();   // 10  利用闭包可以在函数外部进行调用。 */

/* var foo = function(){

    var a = 10;
    return function(){
        console.log(a);
    };

}();

foo(); */

//闭包的好处,防止变量冲突

/*

var foo = function(){

    var a = 10;
    a++;
    console.log(a);

};

foo();
foo();
foo();

var a = 20; */

//我想让a即累加,又是一个局部变量。闭包可以做到

/* var foo = function(){
var a = 10;
return function(){
a++;
console.log(a);
};
}();

foo();
foo();
foo();

var a = 20; */


//匿名函数自执行

// var foo = function(){}();
// function bar(){}();

/* function(){   //默认情况下,程序认为没有名字的函数是函数声明写法
    console.log(123);
}(); */

/* (function(){   // 可以转成表达式
    console.log(123);
})(); */

// +function(){   // 可以转成表达式
//     console.log(123);
// }();

// ~function(){   // 可以转成表达式
//     console.log(123);
// }();

// !function(){   // 可以转成表达式
//     console.log(123);
// }();
匿名函数,也称为拉姆达函数,是一种使用JavaScript函数的强大方式。以下总结了匿名函数的特点: 任何函数表达式从技术上说都是匿名函数,因为没有引用它们的确定的方式; 在无法确定如何引用函数的情况下,递归函数就会变得比较复杂; 递归函数应该始终使用arguments.callee来递归地调用自身,不要使用函数名--函数名可能会发生变化。 当在函数内部定义了其他函数时,就创建了闭包闭包有权访问包含函数内部的所有变量,原理如下: 在后台执行环境中,闭包的作用域链包含着它自己的作用域、包含函数的作用域和全局作用域; 通常,函数的作用域及其所有变量都会在函数执行结束后被销毁; 但是,当函数返回了一个闭包时,这个函数的作用域将会一直在内存中保存到闭包不存在为止;使用闭包可以在JavaScript中模仿块级作用域(JavaScript本身没有块级作用域的概念),要点如下: 创建并立即调用一个函数,这样既可以执行其中的代码,又不会在内存中留下对该函数的引用; 结果就是函数内部的所有变量都会被立即销毁--除非将某些变量赋值给了包含作用域(即外部作用域)中的变量。 闭包还可以用于在对象中创建私有变量,相关概念和要点如下: 即使JavaScript中没有正式的私有对象属性的概念,但可以使用闭包来实现公有方法,而通过公有方法可以访问在包含作用域中定义的变量; 有权访问私有变量的公有方法叫做特权方法; 可以使用构造函数模式、原型模式来实现自定义类型的特权方法,也可以使用模块模式、增强的模块模式来实现单例的特权方法。 JavaScript中的匿名函数和闭包都是非常有用的特性,利用它们可以实现很多功能。不过,因为创建闭包必须维护额外的作用域,所以过度使用它们可能会占用大量内存。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值