码迷,mamicode.com
首页 > Web开发 > 详细

JS闭包

时间:2019-04-02 21:23:04      阅读:230      评论:0      收藏:0      [点我收藏+]

标签:局部变量   ++   修改   作者   释放   通过   bsp   私有变量   json   

闭包是js中的一大特色,也是一大难点。简单来说,所谓闭包就是说,一个函数能够访问其函数外部作用域中的变量。

 

闭包的三大特点为:

1、函数嵌套函数

2、内部函数可以访问外部函数的变量

3、参数和变量不会被回收。

举例来说:

 

function test(){
     var a=1;
     return function(){
       alert(a);
     }
   }
   var try=test();
   try();//弹出a的值

 


这个例子中,变量a在test方法外部是无法访问的,但test方法里面,嵌套了一个匿名函数,通过return返回,test作用域中的变量a,

 

可以在匿名函数中访问。并且当test方法执行后,变量a所占内存并不会释放,以达到嵌套的函数还可以访问的目的。

 

闭包的作用在于,可以通过闭包,设计私有变量及方法。

举例来说:在java中创建perosn类,含有私有变量name。

 

public class Person{
    private String name=wy;
    public Person(val){
       name=val;
    }
    public void setName(val){
       name=val;
    }
    public String getName(){
      return name;
    }
}

 

在js中实现类似java创建类的功能:

 

 

(function(){
            var name="wangyu";
            Person=function (val) {
                name=val;
            }
            Person.prototype.setName=function(val){
                name=val;
            }
            Person.prototype.getName=function () {
                return name;
            }
        })();
      var person1=new Person("sj");
      alert(this.name)//undefined 因为在function作用域外不能访问
      alert(person1.getName());//sj

 

在function里面的name,由于是在function作用域中,所以外部无法访问,但是可以通过创建person对象,调用person的方法,来达到

 

修改和访问name值的目的,类似于java类中的私有变量,外部无法访问,只能通过类方法访问。

再看一个私有变量的例子:

 

var aaa = (function(){
        var a = 1;
        function bbb(){
                a++;
                alert(a);
        }
        function ccc(){
                a++;
                alert(a);
        }
        return {
                b:bbb,             //json结构
                c:ccc
        }
    })();
    alert(aaa.a)//undefined 
    aaa.b();     //2
    aaa.c()      //3

 

总结:

 

1、闭包是指有权访问另一个函数作用域中的变量的函数,创建闭包的最常见的方式就是在一个函数内创建另一个函数,通过另一个函数访问这个函数的局部变量。闭包的缺点就是常驻内存,会增大内存使用量,使用不当很容易造成内存泄露。

 

2、不必纠结到底怎样才算闭包,其实你写的每一个函数都算作闭包,即使是全局函数,你访问函数外部的全局变量时,就是闭包

的体现。
---------------------
作者:yujin0222
来源:CSDN
原文:https://blog.csdn.net/baidu_33295233/article/details/79127733
版权声明:本文为博主原创文章,转载请附上博文链接!

JS闭包

标签:局部变量   ++   修改   作者   释放   通过   bsp   私有变量   json   

原文地址:https://www.cnblogs.com/mlw1814011067/p/10645079.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!