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 相关文章推荐
jQuery 动画基础教程
Dec 25 Javascript
利用JS实现浏览器的title闪烁
Jul 08 Javascript
jquery禁用右键示例
Apr 28 Javascript
jQuery实现的导航动画效果(附demo源码)
Apr 01 Javascript
ECHO.js 纯javascript轻量级延迟加载的实例代码
May 24 Javascript
js实现div模拟模态对话框展现URL内容
May 27 Javascript
Bootstrap的基本应用要点浅析
Dec 19 Javascript
JS动态遍历json中所有键值对的方法(不知道属性名的情况)
Dec 28 Javascript
微信小程序 图片边框解决方法
Jan 16 Javascript
字太多用...代替的方法(两种)
Mar 15 Javascript
jquery select插件异步实时搜索实例代码
Oct 20 jQuery
react国际化react-intl的使用
May 06 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
国内咖啡文化
2021/03/03 咖啡文化
咖啡与水的关系
2021/03/03 冲泡冲煮
ThinkPHP无限级分类原理实现留言与回复功能实例
2014/10/31 PHP
PHP中通过trigger_error触发PHP错误示例
2015/06/23 PHP
PHP实现递归复制整个文件夹的类实例
2015/08/03 PHP
PHP实现数组转JSon和JSon转数组的方法示例
2018/06/14 PHP
PHP实现的用户注册表单验证功能简单示例
2019/02/25 PHP
jquery实现文本框数量加减功能的例子分享
2014/05/10 Javascript
javascript检查浏览器是否支持flash的实现代码
2014/08/14 Javascript
JavaScript实现倒计时代码段Item1(非常实用)
2015/11/03 Javascript
使用jquery datatable和bootsrap创建表格实例代码
2017/03/17 Javascript
windows下vue-cli导入bootstrap样式
2017/04/25 Javascript
基于vue2.0实现的级联选择器
2017/06/09 Javascript
解析Vue 2.5的Diff算法
2017/11/28 Javascript
Vue中使用vee-validate表单验证的方法
2018/05/09 Javascript
JS实现随机生成10个手机号的方法示例
2018/12/07 Javascript
Javascript删除数组里的某个元素
2019/02/28 Javascript
JS实现的碰撞检测与周期移动完整示例
2019/09/02 Javascript
javascript+css实现进度条效果
2020/03/25 Javascript
[03:21]辉夜杯主赛事 12月25日TOP5
2015/12/26 DOTA
Flask SQLAlchemy一对一,一对多的使用方法实践
2013/02/10 Python
Python实现以时间换空间的缓存替换算法
2016/02/19 Python
基于python3 类的属性、方法、封装、继承实例讲解
2017/09/19 Python
Python小程序 控制鼠标循环点击代码实例
2019/10/08 Python
使用python接受tgam的脑波数据实例
2020/04/09 Python
Opencv求取连通区域重心实例
2020/06/04 Python
提高python代码运行效率的一些建议
2020/09/29 Python
Django 权限管理(permissions)与用户组(group)详解
2020/11/30 Python
丹麦优惠购物网站:PLUSSHOP
2019/03/24 全球购物
葡萄牙航空官方网站:TAP Air Portugal
2019/10/31 全球购物
乌克兰鞋类购物网站:Eobuv.com.ua
2020/11/28 全球购物
骨干教师考核评语
2014/12/31 职场文书
结婚纪念日感言
2015/08/01 职场文书
Go各时间字符串使用解析
2021/04/02 Golang
聊一聊python常用的编程模块
2021/05/14 Python
JavaScript实现九宫格拖拽效果
2022/06/28 Javascript