关于JS中的闭包浅谈

 更新时间:2013年08月23日 15:25:12   投稿:shangke  
闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分

个人见解:在函数体内定义另外的方法函数,而这个方法函数被函数以外的变量引用,这时就形成了闭包!

可能这样的理解也太抽象了,并不是那么简单易懂!实例吧:

复制代码 代码如下:

<script type="text/javascript">

function A(){
    var S=0;
    function B(){
        alert(++S);
    }
    return B;
}
var C=A();
C();
</script>

上面这一段代码就创建了一个闭包,因为当函数执行到var C=A();时,表面上看C指向的是A函数,而实际上C所指向的函数是B函数,所以再执行到C()的时候就会输出2;这样的话B函数就被A函数以外的变量引用了,根据个人见解,创建了一个闭包!

当我在小小的了解了什么时候闭包后也顺便看了哈闭包的用途,据说闭包的用途主要有两点:

1、可以读取函数内部的变量

2、让这些变量始终保持在内存中

复制代码 代码如下:

<script type="text/javascript">
 
function A(){
 var S=1;
 D=function(){
        S+=1;
    }
 function B(){
  alert(S);
 }
    return B;
}
var C=A();
C(); // 输出1
D();
C(); // 输出2
  
 </script>

上面的代码中C指向的还是是B函数,C执行了两次,第一次输出1,第二次输出2,这证明了S一直被保存在内存中,并没有在A函数在被调用后自动清除,这是为什么呢,原因是因为B函数被赋给了一个全局变量,这导致了B函数一直在内存中,而B函数的执行又需要依赖着A函数,所以A也一直在内存中,不会在调用结束后被回收!(这样的理解貌似有点不专业)!

表达完毕,请广大群众多多指教!

相关文章

  • 浅谈JavaScript中的Math.atan()方法的使用

    浅谈JavaScript中的Math.atan()方法的使用

    这篇文章主要介绍了JavaScript中的Math.atan()方法的使用,是JS入门学习中的基础知识,需要的朋友可以参考下
    2015-06-06
  • JavaScript创建对象的七种方式全面总结

    JavaScript创建对象的七种方式全面总结

    这篇文章主要介绍了JavaScript创建对象的七种方式,工厂模式,构造函数模式,原型模式等分别在本文中做出了讲解,具体操作步骤大家可查看下文的详细讲解,感兴趣的小伙伴们可以参考一下。
    2017-08-08
  • 微信小程序中显示html格式内容的方法

    微信小程序中显示html格式内容的方法

    最近在工作中遇到一个需求,需要在不能显示html格式的微信小程序中显示html格式的内容,通过查找相关的资料发现可以利用wxParse来实现,下面这篇文章就主要给大家介绍了微信小程序实现显示html格式内容的方法,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-04-04
  • javascript基础数据类型转换教程示例

    javascript基础数据类型转换教程示例

    总结了javascipt中的数据类型之后,我们就了解了,prompt()接收的全是字符串,因此数据类型转换就显得尤为重要,一起来学习一下吧
    2022-03-03
  • javaScript对象和属性的创建方法

    javaScript对象和属性的创建方法

    javaScript对象和属性的创建方法...
    2007-01-01
  • ES5学习教程之Array对象

    ES5学习教程之Array对象

    这篇文章主要给大家介绍了ES5中新增的Array对象的相关资料,文中介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。
    2017-04-04
  • JavaScript 学习笔记(九)call和apply方法

    JavaScript 学习笔记(九)call和apply方法

    两者实现的功能是完全一样的,只是参数传递方式不一样,call是将各个参数以逗号(,)隔开,而apply是将所有参数组成一个数组进行传递。
    2010-01-01
  • 整理JavaScript对DOM中各种类型的元素的常用操作

    整理JavaScript对DOM中各种类型的元素的常用操作

    这篇文章主要介绍了JavaScript对DOM中各种类型的元素的常用操作整理,DOM操作是JavaScript程序的一大根本任务,需要的朋友可以参考下
    2016-05-05
  • JavaScript中的toLocaleDateString()方法使用简介

    JavaScript中的toLocaleDateString()方法使用简介

    这篇文章主要介绍了JavaScript中的toLocaleDateString()方法使用简介,是JS入门学习中的基础知识,需要的朋友可以参考下
    2015-06-06
  • js nextSibling属性和previousSibling属性概述及使用注意

    js nextSibling属性和previousSibling属性概述及使用注意

    nextSibling属性:该属性表示当前节点的下一个节点;如果其后没有与其同级的节点,则返回null;previousSibling属性:该属性与nextSibling属性的作用正好相反,接下来将详细介绍下,感兴趣的你不妨了解下哦,或许对你有所帮助
    2013-02-02

最新评论