首页 > web前端 > js教程 > js 闭包常见的两种情况的解析

js 闭包常见的两种情况的解析

一个新手
发布: 2017-09-22 10:24:32
原创
1167 人浏览过

//闭包两种情况  1:函数作为返回值
function fn() {
    var max =10;
    return function bar(x) {
        if(x > max){
          console.log(x)
        }else{
            console.log(666)
        }
    }
}
var f1=fn(),max = 100;
f1(15)    //15
//这里fn()赋给f1,调用f1时,即执行bar函数,此时x=15,
//max的取值需是创建该函数的作用域内,即max=10;最后输出15.
登录后复制
//2:函数作为参数传递
    var max=10,
        fn=function (x) {
            if(x > max){
                console.log(x)
            }else{
                console.log('000')
            }
        };
        (function (f) {
            var max = 100;
            f(15)
        })(fn)
    //这是第二种情况,fn函数作为f参数,f(15)就是执行 fn(15);
    //此时x=15,max的取值应该是创建fn函数的作用域内取,即10,输出结果是15;
登录后复制

以上是js 闭包常见的两种情况的解析的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板