分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 代码编程

js闭包

发布时间:2023-09-06 02:14责任编辑:赖小花关键词:js闭包

先展示两段代码块看看到底有什么区别

function foo(x) { ???var tmp = 3; ???return function (y) { ???????alert(x + y + (++tmp)); ???}}foo(2)(10);
function foo(x) { ???var tmp = 3; ???function bar(y) { ???????alert(x + y + (++tmp)); ???} ???bar(10);}foo(2)

这两段代码都是alert(16),区别到底在哪。

代码块①出现了闭包。

准确来说 这块就是一个闭包。

闭包是基于正常的垃圾回收处理机制下的。也就是说,一般情况一个函数(函数作用域)执行完毕,

里面声明的变量会全部释放,被垃圾回收器回收。但闭包利用一个技巧,让作用域里面的变量,

在函数执行完之后依旧保存没有被垃圾回收处理掉。

或者说一下我现在的一个需求

我需要在for循环里面进行事件的绑定,这个应该怎么操作?

第一反应是这样(原生js)

<script>window.onload=function(){ ???var list = [‘a‘,‘b‘]; ???for(var i in list){ ???????document.getElementById(list[i]).onclick=function(){ ???????????alert(list[i]); ???????} ???}}</script></head><body> ???<div id="a">aaa</div> ???<div id="b">bbb</div></body>

可以尝试一下,绝对都是alert(b)

原因就是执行完之后变量i被回收了。

可以换另一中方式

<script>window.onload=function(){ ???var list = [‘a‘,‘b‘]; ???for(var i in list){ ???????(function(j){ ???????????document.getElementById(list[j]).onclick=function(){ ???????????????alert(list[j]); ???????????} ???????})(i) ???}}</script></head><body> ???<div id="a">aaa</div> ???<div id="b">bbb</div></body>

使用闭包来解决。nice!!!

我的low逼见解,前端了解就是。

js闭包

原文地址:https://www.cnblogs.com/c-h-y/p/9631686.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved