JavaScript知识点总结(十六)之Javascript闭包(Closur(3)

var name = "The Window";//全局变量name //全局对象object var object = {     name : "My Object",     getNameFunc : function(){ /* 此时这个this代表的是哪个对象呢,this此时代表的是object对象,哪个对象调用this所在的函数,this指的就是哪个对象 执行完that = this后,此时that也代表object对象 */ var that = this;//that是在getNameFunc函数里面声明的一个局部变量 //证明getNameFunc函数里面的this代表的是object对象而不是window alert("this==object的结果是:"+(this==object)); alert("this==window的结果是:"+(this==window)); //证明that代表的是object对象 alert("that==object的结果是:"+(that==object));       return function(){ /*that是在getNameFunc函数里面声明的一个局部变量, 正常情况下getNameFunc函数调用完成后,that这个局部变量就会被JavaScript的GC回收,释放掉that这个局部变量所占用的内存空间, 但是现在that却能一直正常使用,没有被回收, 原因就在于getNameFunc是这个匿名函数的父函数,而getNameFunc函数调用完后会将这个匿名函数返回并被赋给了一个全局变量retFn,这导致匿名函数始终在内存中, 而匿名函数的存在依赖于getNameFunc函数,因此getNameFunc函数也始终在内存中,不会在调用结束后,被垃圾回收机制(garbage collection)回收。 既然getNameFunc函数始终在内存中,那么在getNameFunc函数内部声明的that局部变量在内存中也会一直存在,既然存在,那么当然可以继续使用了。 */         return that.name;//that代表的是object对象,那么that.name访问的自然就是object对象的名字"My Object"       };     }   }; var retFn = object.getNameFunc();//调用完getNameFunc方法后,返回一个匿名方法,此时retFn代表的就是匿名方法,现在相当于给匿名方法起了一个名字叫retFn   alert(retFn());

最后也附上一个我以前学习JavaScript闭包时写的一个例子:

<script type="text/javascript"> function A(){ var i = ;//声明在A函数内部的局部变量i //声明在A函数的内部的子函数b function b(){ alert("i = "+(++i));//在子函数b内部访问声明在A函数内部的局部变量i } return b;//返回b这个函数的地址 } /* 在执行完var c = A()后,变量c实际上是指向了函数b,b中用到了变量i, 再执行c()后会弹出一个窗口显示i的值(第一次为), 这段代码其实就是创建了一个闭包, 因为函数a外的变量c引用了函数a内部的函数b 也就是说:当函数a的内部函数b被函数a外的一个变量引用的时候, 就创建了一个所谓的"闭包" 闭包的作用就是在a执行完并返回后, 闭包使得JavaScript的垃圾回收机制GC不会收回a所占用的资源, 因为a的内部函数b的执行需要依赖a中的变量 */ A();//此时内存中肯定会有i的空间,当执行完A()之后,GC就会回收为i分配的内存空间 var c = A();//这种用法,GC不会把i当成垃圾处理掉 c();//相当于调用b(),结果是:i= c();//结果是:i= c();//结果是:i= </script>

运行结果:

JavaScript知识点总结(十六)之Javascript闭包(Closur

以上内容是小编给大家介绍的JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解的相关内容,希望对大家有所帮助!

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wzpwws.html