首页 > web前端 > js教程 > 正文

一句话概括:什么是闭包?

零下一度
发布: 2017-06-26 15:47:40
原创
2581人浏览过

一句话概括的话:闭包就是一个函数,捕获作用域内的外部绑定。

官方的定义:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因为这些变量也称为该表达式的一部分。

自由变量和闭包的关系:自由变量闭合于闭包的创建。

内部逻辑就是

自由变量:如果一个函数内部有其他函数,那么这些内部函数可以访问外部函数中声明的变量(这些变量就称为自由变量)。

闭包的三个特性:

1.函数嵌套函数

2.函数内部可以引用外部的参数和变量

3.参数和变量不会被垃圾回收机制回收

闭包的缺点是常驻内存,会增大内存的使用量,使用不当很容易造成内存泄露.

闭包的好处:

1.希望一个变量可以长期驻扎在内存中

豆包爱学
豆包爱学

豆包旗下AI学习应用

豆包爱学 674
查看详情 豆包爱学

2.避免全局变量的污染

3.私有成员的存在

function fn(){//闭包 fn()
  var a = 10;
  function f1(){
  a++;
  console.log(a);
  }
  return f1;
  }
  var f = fn();
  f();
  f();
  f(); 

闭包解决索引值问题:

 

 

  <!DOCTYPE html>
  <html>
  <head>
  <meta charset="UTF-8">
  <title></title>
  </head>
  <body>
  <ul>
  <li>1</li>
  <li>2</li>
  <li>3</li>
  <li>4</li>
  </ul>
  </body>
  <script type="text/javascript">
  window.onload = function(){
  var aLi = document.getElementsByTagName("li");
  for(var i=0;i<aLi.length;i++){
  // (function(i){
  // aLi[i].onclick = function(){//当我们点击时for循环已经结束
  // alert(i)
  // }
  // })(i)
   
  aLi[i].onclick=function(index){
  return function(){
  alert(index);
  }
  }(i)
  }
  }
  </script>
  </html>
 

内存泄漏问题:

ie的js对象和dom对象使用不同的垃圾回收机制,因此闭包在ie中会导致内存泄露问题,也就是无法销毁驻留在内存中的元素。

function closure(){
  var oDiv = document.getElementById("div1");//oDiv用完之后一直驻留在内存
   
  oDiv.onclic = function(){
  alert("oDiv.innerHTML");//这里用oDiv会导致内存泄露
  };
   
 

closure();

 

//将oDiv解除引用来避免内存泄露 function closure(){ var oDiv = document.getElementById("div1");//oDiv用完之后一直驻留在内存 var test = oDiv.innerHTM oDiv.onclic = function(){ alert(test);//这里用oDiv会导致内存泄露 }; oDiv = null; } 

以上就是一句话概括:什么是闭包?的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号