javaScript学习笔记之-------闭包

提到闭包,就不能不提的---变量作用域

变量作用域:全局变量和局部变量

js语言本身的独特之处:就是可以在函数内部读取使用全局变量

那么问题来了,,如何在函数外部使用函数内部命名的变量   

杀手锏----闭包

举例说明:

知识点:this指的是全局 

 
 var age= "19";
   var object = {
    age: "9",
    getAgeFunc : function(){
      return function(){
        return this.age;
      };
    }
  };
  alert(object.getAgeFunc ()());//19
 

附上差异点:

 

其实两者的主要区别就是区别就是第一个程序在执行完第一段()的时候把里面的作用域scope抛弃了,而第二个程序在执行完第一段()的时候把里面的作用域scope赋给一个变量一并返回得到了暂存状态,所以执行二段()的时候,

第一个程序由于抛弃了所以this直接指向window,第二个程序的this.指的自然是那个变量

 

知识点:  this  指的是object对象

    var age = "19";
    var object = {
        age : "9",
        getAgeFunc : function(){
            var that = this;
            return function(){
                return that.age ;
            };
        }
    };
    alert(object.getAgeFunc()());//9

 

以前觉得尤其困难的闭包,,理解后是这么可爱

 

posted @ 2019-01-23 11:36  donglt  阅读(126)  评论(0编辑  收藏  举报