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 Cookie显示用户上次访问的时间和次数
Dec 08 Javascript
jQuery ajax cache缓存问题
Jul 01 Javascript
alert和confirm功能介绍
May 21 Javascript
EasyUI实现二级页面的内容勾选的方法
Mar 01 Javascript
JavaScript判断手机号运营商是移动、联通、电信还是其他(代码简单)
Sep 25 Javascript
JS实现IE状态栏文字缩放效果代码
Oct 24 Javascript
使用postMesssage()实现跨域iframe页面间的信息传递方法
Mar 29 Javascript
jQuery 判断是否包含在数组中Array[]的方法
Aug 03 Javascript
Vue.js第二天学习笔记(vue-router)
Dec 01 Javascript
Layui table 组件的使用之初始化加载数据、数据刷新表格、传参数
Sep 11 Javascript
vue安装和使用scss及sass与scss的区别详解
Oct 15 Javascript
JavaScript的词法结构精华篇
Oct 17 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
php实现编辑和保存文件的方法
2015/07/20 PHP
详解WordPress中调用评论模板和循环输出评论的PHP函数
2016/01/05 PHP
PHP正则表达式过滤html标签属性(DEMO)
2016/05/04 PHP
JavaScript中也使用$美元符号来代替document.getElementById
2010/06/19 Javascript
javascript动画浅析
2012/08/30 Javascript
javascript数组输出的两种方式
2015/01/13 Javascript
JQuery中$.each 和$(selector).each()的区别详解
2015/03/13 Javascript
JavaScript跨平台的开源框架NativeScript
2015/03/24 Javascript
AngularJs 60分钟入门基础教程
2016/04/03 Javascript
利用JavaScript判断浏览器类型及版本
2016/08/23 Javascript
深入理解JavaScript中的并行处理
2016/09/22 Javascript
JS控制HTML元素的显示和隐藏的两种方法
2016/09/27 Javascript
vue-music关于Player播放器组件详解
2017/11/28 Javascript
vue计算属性和监听器实例解析
2018/05/10 Javascript
vue的传参方式汇总和router使用技巧
2018/05/22 Javascript
vue之a-table中实现清空选中的数据
2019/11/07 Javascript
javascript严格模式详解(含严格模式与非严格模式的区别)
2019/11/12 Javascript
Python上传package到Pypi(代码简单)
2016/02/06 Python
python 线程的暂停, 恢复, 退出详解及实例
2016/12/06 Python
python实现树形打印目录结构
2018/03/29 Python
详解python中sort排序使用
2019/03/23 Python
使用Python操作ArangoDB的方法步骤
2020/02/02 Python
Python判断三段线能否构成三角形的代码
2020/04/12 Python
用Java语言将一个键盘输入的数字转化成中文输出
2013/01/25 面试题
医学护理毕业生自荐信
2013/11/07 职场文书
银行出纳岗位职责
2013/11/25 职场文书
大学辅导员事迹材料
2014/02/05 职场文书
四风查摆剖析材料
2014/10/10 职场文书
给医院的感谢信
2015/01/21 职场文书
公司租车协议书
2015/01/29 职场文书
情人节活动总结范文
2015/02/05 职场文书
现实表现证明材料
2015/06/19 职场文书
致运动员加油稿
2015/07/21 职场文书
python 解决微分方程的操作(数值解法)
2021/05/26 Python
jupyter notebook保存文件默认路径更改方法汇总(亲测可以)
2021/06/09 Python
Linux中各个目录的作用与内容
2022/06/28 Servers