js闭包学习心得总结


Posted in Javascript onApril 17, 2018

首先引用来自官网文档的定义:

closure is the combination of a function and the lexical environment within which that function was declared.

闭包是一个函数和其内部公开变量的环境的集合.

简单而言, 闭包 = 函数 + 环境

第一个闭包的例子

function init() {
 var name = 'Mozilla'; // name is a local variable created by init
 function displayName() { // displayName() is the inner function, a closure
 alert(name); // use variable declared in the parent function 
 }
 displayName(); 
}
init();

because inner functions have access to the variables of outer functions, displayName() can access the variable name declared in the parent function, init().

其实这个栗子很简单,displayName()就是init()内部的闭包函数,而为啥在displayName内部可以调用到外部定义的变量 name 呢,因为js内部函数有获取外部函数中变量的权限。

第二个例子

var data = [
 {'key':0},
 {'key':1},
 {'key':2}
];
function showKey() {
 for(var i=0;i<data.length;i++) {
   setTimeout(function(){
    //console.log(i); //发现i输出了3次3
   //console.log(this); // 发现 this 指向的是 Window
   data[i].key = data[i].key + 10;
   console.log(data[i].key)
   }, 1000);
 }
}
showKey();

上面这个例子可以正确输出 10 11 12 吗?

答案是:并不能,并且还会报语法错误....

console.log(i); 发现i输出了3次3,也就是说,在setTimeout 1000毫秒之后,执行闭包函数的时候,for循环已经执行结束了,i是固定值,并没有实现我们期望的效果。

console.log(this); 发现 this 指向的是 Window,也就是说,在函数内部实现的闭包函数已经被转变成了全局函数,存储到了内存中。

所以需要再定义一个执行函数

var data = [
 {'key':0},
 {'key':1},
 {'key':2}
];
function showKey() {
 var f1 = function(n){
  data[i].key = data[i].key + 10;
  console.log(data[i].key)
 }
 for(var i=0;i<data.length;i++) {
   setTimeout(f1(i), 1000);
 }
}
showKey();
// 得到预期的 10 11 12
Javascript 相关文章推荐
javascript与webservice的通信实现代码
Dec 25 Javascript
jQuery前台数据获取实现代码
Mar 16 Javascript
js中的push和join方法使用介绍
Oct 08 Javascript
前端轻量级MVC框架CanJS详解
Sep 26 Javascript
js实例属性和原型属性示例详解
Nov 23 Javascript
JSON 的正确用法探讨:Pyhong、MongoDB、JavaScript与Ajax
May 15 Javascript
bootstrap multiselect 多选功能实现方法
Jun 05 Javascript
vue2.0 自定义日期时间过滤器
Jun 07 Javascript
Vue.js添加组件操作示例
Jun 13 Javascript
layui问题之模拟select点击事件的实例讲解
Aug 15 Javascript
socket在egg中的使用实例代码详解
May 30 Javascript
微信小程序自定义波浪组件使用方法详解
Sep 21 Javascript
Vue使用json-server进行后端数据模拟功能
Apr 17 #Javascript
js实现点击按钮复制文本功能
Jul 20 #Javascript
Element-UI Table组件上添加列拖拽效果实现方法
Apr 14 #Javascript
React中的render何时执行过程
Apr 13 #Javascript
全站最详细的Vuex教程
Apr 13 #Javascript
vue的常用组件操作方法应用分析
Apr 13 #Javascript
简单的vuex 的使用案例笔记
Apr 13 #Javascript
You might like
Web程序工作原理详解
2014/12/25 PHP
PHP提高编程效率的20个要点
2015/09/23 PHP
php中__toString()方法用法示例
2016/12/07 PHP
PHP获取当前URL路径的处理方法(适用于多条件筛选列表)
2017/02/10 PHP
到处都是jQuery选择器的年代 不了解它们的性能,行吗
2012/06/18 Javascript
告诉你什么是javascript的回调函数
2014/09/04 Javascript
JS中多步骤多分步的StepJump组件实例详解
2016/04/01 Javascript
javascript冒泡排序小结
2016/04/10 Javascript
JS实现将Asp.Net的DateTime Json类型转换为标准时间的方法
2016/08/02 Javascript
解决vue router使用 history 模式刷新后404问题
2017/07/19 Javascript
详解Nodejs mongoose
2018/06/10 NodeJs
详解webpack自定义loader初探
2018/08/29 Javascript
[01:02]DOTA2辉夜杯决赛日 CDEC.Y对阵VG赛前花絮
2015/12/27 DOTA
[29:59]完美世界DOTA2联赛PWL S3 Forest vs access 第二场 12.11
2020/12/13 DOTA
python求列表交集的方法汇总
2014/11/10 Python
python实现定时播放mp3
2015/03/29 Python
python3.5 + PyQt5 +Eric6 实现的一个计算器代码
2017/03/11 Python
Python中scatter函数参数及用法详解
2017/11/08 Python
使用11行Python代码盗取了室友的U盘内容
2018/10/23 Python
python 列表转为字典的两个小方法(小结)
2019/06/28 Python
python3 selenium自动化测试 强大的CSS定位方法
2019/08/23 Python
tensorflow 保存模型和取出中间权重例子
2020/01/24 Python
在服务器上安装python3.8.2环境的教程详解
2020/04/26 Python
澳大利亚排名第一的儿童在线玩具商店:Toy Galaxy
2018/10/06 全球购物
娇韵诗俄罗斯官方网站:Clarins俄罗斯
2020/10/03 全球购物
介绍一下如何优化MySql
2016/12/20 面试题
机电专业个人自荐信格式模板
2013/09/23 职场文书
投标邀请书范文
2014/01/31 职场文书
《蜗牛的奖杯》教后反思
2014/04/24 职场文书
2015年市场部工作总结
2015/04/30 职场文书
寻找最美乡村教师观后感
2015/06/18 职场文书
培根随笔读书笔记
2015/07/01 职场文书
九年级语文教学反思
2016/03/03 职场文书
Python使用scapy模块发包收包
2021/05/07 Python
springboot读取resources下文件的方式详解
2022/06/21 Java/Android
springboot创建的web项目整合Quartz框架的项目实践
2022/06/21 Java/Android