JS进阶-闭包的几种常见形式

本文深入探讨了JavaScript中的作用域链概念,包括全局作用域、局部作用域和词法作用域的区别,以及如何利用闭包突破作用域限制,实现变量的持久存储。通过具体示例,展示了闭包在保持函数内部状态方面的应用。

作用域链:

//作用域链
    var a = 1;
    function test() {
        var b =2;
        return a;
    }
    alert(test());//弹出1;
    alert(b);//不能获取b
//scope chain
    var a = 1;
    function test() {
        var b = 2;
        function test1() {
            var c = 3;
            alert(a);
            alert(b);
            alert(c);
        }
        test1();
    }
    test();//弹出1,弹出2,弹出3;

词法作用域:

//词法作用域;
    function f1() {
        var a = 12;
        return f2();
    }
    function f2() {
        return a;
    }
    alert(f1());//并不能获取a,a在f2()中并未定义;
function f1() {
        var a = 1;
        return f2();
    }
    function f2() {
        var b = 3;
        alert(b);
        return a;
    }
    alert(f1());//弹出3,a在f2()中未定义
function f1() {
        var a = 1;
        return f2();
    }
    function f2() {
        var b = 3;
        alert(b);
        return a;
    }
    alert(f1());//弹出3,a在f2()中未定义,undefined
    var a=55;
    alert(f1());//弹出3,弹出55

如何通过闭包突破全局作用域链——几种常见形式

//通过闭包突破全局作用域链
    function f() {
        var a = "sun";
        return function () {
            return a;
        }
    }
    var test = f();
    alert(test());//弹出sun
var n;
function f() {
    var a = "sun";
    n = function () {
        return a;
    }
}
f();
alert(n());//弹出sun
   function f(param) {
        var n =function () {
            return param;
        };
        param  ;
        return n;
    }
    var test = f(45);
    alert(test());//弹出46;

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值