闭包是指有权访问另一个函数作用于中的变量的函数。最长见得闭包就是在一个函数内部创建另一个函数。
在另一个函数内部定义的函数会将包含外部函数的活动对象添加到内部函数中创建的那个函数的作用域链中。
例:
function createFunction(propertyName) {
return function (object1,object2) {
var value1=object1[propertyName];
var value2=object2[propertyName];
if(value1<value2){
// .......;
}
};
}
在createFunction()函数中定义的匿名函数的作用域链将会包含createFunction()函数活动对象。
在匿名函数从createFunction()函数中返回后,他的作用域链被初始化为包含createFunction()函数的活动对象和全局变量对象。这样,匿名函数就可以访问createFunction()函数中定义的所用变量。更为重要的是,createFunction()函数在执行完以后,其活动对象并不会被销毁,因为匿名函数的作用链中任然在引用这个活动对象。换句话说,当createFunction()函数返回后,它的执行环境的作用域链会被销毁,但活动对象任然留在内存中被匿名函数引用;直到匿名函数被销毁后,createFunction()的活动对象才会被销毁。
例:
var comNames=createFunction("name"); //创建函数
var result=comNames({name:"fx"},{name:"wjh"}); //调用函数
comNames=null; //解除对匿名函数的引用(以便释放内存)
由于闭包会携带包含函数的作用域,因此会比其他函数占用更多的内存;
//读JavaScript高级程序设计
在另一个函数内部定义的函数会将包含外部函数的活动对象添加到内部函数中创建的那个函数的作用域链中。
例:
function createFunction(propertyName) {
return function (object1,object2) {
var value1=object1[propertyName];
var value2=object2[propertyName];
if(value1<value2){
// .......;
}
};
}
在createFunction()函数中定义的匿名函数的作用域链将会包含createFunction()函数活动对象。
在匿名函数从createFunction()函数中返回后,他的作用域链被初始化为包含createFunction()函数的活动对象和全局变量对象。这样,匿名函数就可以访问createFunction()函数中定义的所用变量。更为重要的是,createFunction()函数在执行完以后,其活动对象并不会被销毁,因为匿名函数的作用链中任然在引用这个活动对象。换句话说,当createFunction()函数返回后,它的执行环境的作用域链会被销毁,但活动对象任然留在内存中被匿名函数引用;直到匿名函数被销毁后,createFunction()的活动对象才会被销毁。
例:
var comNames=createFunction("name"); //创建函数
var result=comNames({name:"fx"},{name:"wjh"}); //调用函数
comNames=null; //解除对匿名函数的引用(以便释放内存)
由于闭包会携带包含函数的作用域,因此会比其他函数占用更多的内存;
//读JavaScript高级程序设计