我认知的闭包
在我的认知里面:是一个函数a里面还有一个函数b(就是函数的嵌套),并且函数a把里面的函数b给return。像下面的这个样子☟☟☟(嘿!我喜欢写中文。)
<script type="text/javascript">
//函数a
function 函数a(){
//函数a里面嵌套的函数b
function 函数b(){
var 变量1="嘿嘿,我是变量1,期待你的访问!"
return 变量1; //函数b返回的变量
}
return 函数b; //函数a返回了函数b
}
</script>
这就是一个javascript的闭包了。
它使用起来是这样的:调用函数a,然后返回函数b,在执行函数b。嗯,就酱。
<script type="text/javascript">
//接着上面的代码执行
var 返回的函数b=函数a();//通过调用函数a,可以获取到里面的函数b
var 结果是啥=返回的函数b(); //执行函数b
//弹出一个结果
alert(结果是啥);
</script>
看这就是结果:
我的认知就到了这里,好像知道点儿什么,又好像是啥也不啥?[太极的最高境界]
前两天有幸看到了一篇介绍闭包的文章,让我又有了进一步的认识。
闭包新的打开方式?
直接上代码:
<script type="text/javascript">
var 变量2="啪啪啪!变量二来了?"; //一个局部变量2
function 函数3(){
alert(变量2); //弹出一个变量2
}
函数3(); //执行一下函数3
</script>
他执行出来的结果就是:
做到这里我好想明白了闭包是什么东西。
这就是闭包
结合上面的这两个例子,得出闭包就是:函数和函数内部能访问到的变量的集合,就是一个闭包。
闭包的作用?
闭包常常用来间接访问一个变量。换句话说,隐藏一个变量。
一个来自其他作者的经验
编程界崇尚以简洁优雅为美,很多时候
如果你觉得一个概念很复杂,那么很可能是你理解错了。
欢迎关注,一起交流,共同进步!