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创建一个运行期上下文,创建一个活动对象,

如图

 



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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值