`
yxc_gdut
  • 浏览: 95914 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

js 闭包作用域链

阅读更多

接上篇 js 函数作用域

还是用那个例子

<script>
	function addEvents(){
		var id = “form1”;
document.getElementById(“save_button”).onclick = function(event){
	sumitForm(id);
};
}
</script>

 

addEvent函数中还有一个function函数,addEvent函数未执行的时候,浏览器不会去创建里面的function,当addEvent执行的时候,浏览器会为function初始化scope属性,addEvent活动对象也属于scope中一员,

如图:


 

所以当addEvent被执行完毕的时候,活动对象被function引用,是不会被销毁,闭包就是这样占用内存,而且变量访问层次更深。

 

当单击save_button执行function的时候,浏览器会为function创建一个运行期上下文,创建一个活动对象,

如图

 



 如果我的理解有误,请提出,谢谢。

  • 大小: 24.7 KB
  • 大小: 21.9 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics