闭包特性:可以让定义好的函数作用域在调用时发生改变,具体说,调用运行时,可以让(定义时)作用域外其他函数访问到本函数的局部变量甚至参数。举例代码如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <script> function personOne(){ var name="huanhuan"; function test(){return name;} return test; } function personTwo(){ return personOne()(); //personOne()返回属性test()函数对象,再执行一次取得值,为"huanhuan" } console.log(personTwo()); //"huanhuan" </script> </body> </html>
personOne()定义完成时作用域链已确定,外部函数不能访问其内部局部变量及参数,但在personTwo()调用时发生了改变,可以访问到前者的局部变量。这个特性是个技巧点,也容易带来一些麻烦。
闭包的作用主要有三点:
第一点:控制作用域内的变量外泄,因为js中不存在块级作用域容易造成块内作用域的变量跑出,但是可以用闭包思想进行控制,形式一般如下:
(function(){ var i; var a; })(i=3,a=5);
第二点:可以让外部其他的作用域访问到本内部作用域中内容。
第三点:可以模仿私有变量的获得:
function fn1(){ var pro1="pro1"; this.fn2=function(){return pro1;} } var ob1=new fn1(); ob1.fn2(); //return "pro1"