js闭包是一个拥有许多变量和绑定了这些变量的环境的表达式。
闭包的特点:
1、作为一个函数变量的一个引用,当函数返回时,其处于激活状态,一个闭包就是当一个函数返回时,一个没有释放资源的栈区。
2、js闭包允许使用内部函数,这些内部函数可以访问它们所在的外部函数中声明的参数和声明的其他内部函数。当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包。
扩展资料:
js闭包实例:
1、函数内部可以直接读取全局变量
<script type="text/javascript">
var n=100
function parent(){
alert(n)
}
2、读取函数内的局部变量
parent()//100
</script>
function parent(){
m=50
}
parent()
alert(m)//50
参考资料来源:百度百科:javascript闭包
闭包是:指有有访问另一个函数作用域中的变量的函数。
创建闭包的常用方式:在一个函数内部创建一个函数。例子:
functioncreateFunction(name){return function(obj1, obj2){
var value1 = obj1[name]
var value2 = obj2[name]
return value1 + ", " +value2
}
}
了解创建作用域以及作用域有什么作用的细节,对彻底理解闭包到头重要。当某个函数被调用时,会创建一个执行环境及相应的作用域链。然后,使用arguments和其他参数的值来初始化函数的活动对象。
一、闭包
1、createFunction()创建时,它(compare)的作用域包含createFunction()函数的活动对象和全局对象。
//创建函数var compare = createFunction("name")
console.log(typeofcompare) //function
2、匿名函数被执行时,创建自己的活动对象和可以访问createFunction()的执行环境。
//调用函数var result =compare({name: "jjaiy"}, {name:"ascy"}) //jjaiyy, ascy
3、createFunction()函数执行完后,其执行环境的作用域不会被销毁。原因在于它的活动对象还在内存中,直到匿名函数被销毁。
//解除对匿名函数的引用(以便释放内存)compare = null
原因在于:
浏览器的垃圾收集方式有:
标记清除(主要针对变量)
引用计数(跟踪记录每个值被引用的次数)
二、实例运行
封装功能
var route = {routes: {},
for: function(path, handler){ //闭包
this.routes[path] = handler //引用回调函数
}
}
//执行二个匿名函数
route.for("/start",function(request, response){
response.writeHead(200,{"Content-Type": "text/plain"})
response.write("Hello")
response.end()
})
route.for("/finish",function(request, response){
response.writeHead(200,{"Content-Type": "text/plain"})
response.write("Goodbye")
response.end()
})
//先判断argument中的path变量是否一致,能否调用其函数中的回调函数。
if(typeof route.routes["/finish"] === 'function'){
route.routes["/finish"](request, response)
}