变量的作用域:
要理解闭包,首先必须理解Javascript特殊的变量作用域。
变量的作用域无非就是两种:全局变量和局部变量。
Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量。
闭包的概念:闭包就是能够读取其他函数内部变量的函数。由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数"。所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。
闭包的用途:一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。
闭包注意事项:由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。
test:function(){
var mm = 1
function tt(){ //匿名函数
//return mm
cc.log(mm)
}
this.add = function (){ //定义的全局变量 把 tt 方法赋予这个全局变量 让 mm 自加
mm++
}
return tt //返回 tt 收到的值
},
init:function()
{
var ww = this.test() //定义的一个局内变量 储存方法test 的值
ww() //可以收到 test 方法体的值 他的值是 1
this.add() //调用了 全局变量的add 的方法 这个方法使传入的变量 自加了 1
ww() //这个时候 ww就变成2
var mm = 1
function tt(){ //匿名函数
//return mm
cc.log(mm)
}
this.add = function (){ //定义的全局变量 把 tt 方法赋予这个全局变量 让 mm 自加
mm++
}
return tt //返回 tt 收到的值
},
init:function()
{
var ww = this.test() //定义的一个局内变量 储存方法test 的值
ww() //可以收到 test 方法体的值 他的值是 1
this.add() //调用了 全局变量的add 的方法 这个方法使传入的变量 自加了 1
ww() //这个时候 ww就变成2
}