javascript-closure

本文深入探讨JavaScript中的闭包概念,通过实例演示了如何创建及使用闭包,包括将其作为返回值和参数的应用场景。此外,还展示了如何利用闭包实现私有变量。

 

//函数当作返回值的时候变成了闭包
var gunFactory = function(howToShoot) {
    var shoot = "How to shoot: " + howToShoot;
    var gun = function() {
        console.log(shoot)
    };
    return gun; // gun 变量存放的是函数,这个函数就是一个闭包,因为你把它当成返回值在函数间传递了
}

gunFactory("bi bi bi")(); //will print :  How to shoot: bi bi bi
gunFactory("ba ba ba")(); //will print :  How to shoot: ba ba ba

//函数当作参数的时候变成了闭包
var shoot = function(howToShoot) {
    howToShoot();
}

var aShoot = "bi bi bi";
var howToShoot = function() {
    console.log("How to shoot: " + aShoot) // aShoot变量被howToShoot函数使用了,所以闭包内就有 aShoot这个变量了,被打包进去了
}

shoot(howToShoot); // howToShoot 是一个变量,存的也是一个函数,因为函数被当成参数传递给了shoot()函数,所以它也是一个闭包


$("#xxx").click(function() { //匿名函数当闭包
    console.log("xxx")
})
//以上代码等价于
var callback = function() {
    console.log("xxx")
};
$("#xxx").click(callback) //可以看出callback就是一个函数,因为被当成了参数,所以就是一个闭包

$("#xxx").click(function() {  //所以这个匿名函数就是一个闭包,虽然没有名字
    console.log("xxx")
})



function f() { //第一层
    var a;
    return function () { //第二层
        var b;
        return function() { //第三层
            console.log(a + "," + b);
        }
    }
}

var r = f()(); // 调用 f() 返回第二层的函数 ,再次 调用这个函数,返回第三层的函数,那么r就是第三层的函数。
//因为第三层函数内使用了 a 和 b变量,所以,r就是一个第三层函数的闭包,并且闭包内包含了 a b的引用的闭包,并且闭包内包含了 a b的引用
//只要 r 变量还有人使用,那么a 和 b 就一直可以被使用


//利用闭包可以模拟出私有变量,就是不允许别人直接访问的变量,比如
var MyClass = function() {
    var name = "super";
    this.age = 10;

    this.show = function() {
        console.log("name: " + name + ", this.age: " + this.age); //因为引用了 name 所以,name 成了闭包中被打包的属性
    }
}

var anInstance = new MyClass();
anInstance.show(); // 会打印出  name: super, age: 10
anInstance.age = 20; //age是对象的属性,可以任意变更
anInstance.show(); //会打印出 name: super, age: 20
anInstance.name = "stupid"; // 这行不会出错,但是改变的name 是闭包内的变量,但不是 anInstance对象的变量
anInstance.show(); //回打印出 name: super, age: 20

 

转载于:https://my.oschina.net/lovemiao/blog/3031451

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值