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入门教程(10) 认识其他对象
Jan 31 Javascript
JS将光标聚焦在文本最后的实现代码
Mar 28 Javascript
angularJS中router的使用指南
Feb 09 Javascript
Jquery1.9.1源码分析系列(六)延时对象应用之jQuery.ready
Nov 24 Javascript
在Html中使用Requirejs进行模块化开发实例详解
Apr 15 Javascript
javascript解决小数的加减乘除精度丢失的方案
May 31 Javascript
浅谈JavaScript变量的自动转换和语句
Jun 12 Javascript
JS实现iframe自适应高度的方法(兼容IE与FireFox)
Jun 24 Javascript
浅谈js中StringBuffer类的实现方法及使用
Sep 02 Javascript
vue-router路由懒加载和权限控制详解
Dec 13 Javascript
使用D3.js创建物流地图的示例代码
Jan 27 Javascript
JS实现li标签的删除
Apr 12 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设计模式之单例模式使用示例
2014/01/20 PHP
PHP多线程编程之管道通信实例分析
2015/03/07 PHP
php实现给二维数组中所有一维数组添加值的方法
2017/02/04 PHP
php常用字符串查找函数strstr()与strpos()实例分析
2019/06/21 PHP
javascript在一段文字中的光标处插入其他文字
2007/08/26 Javascript
关于 文本框默认值 的操作js代码
2012/01/12 Javascript
extjs3 combobox取value和text案例详解
2013/02/06 Javascript
JS+CSS实现仿支付宝菜单选中效果代码
2015/09/25 Javascript
js和jquery分别验证单选框、复选框、下拉框
2015/12/17 Javascript
FullCalendar日历插件应用之数据展现(一)
2015/12/23 Javascript
ajax的分页查询示例(不刷新页面)
2017/01/11 Javascript
JavaScript中document.referrer的用法详解
2017/07/04 Javascript
基于Vue.js 2.0实现百度搜索框效果
2020/12/28 Javascript
JS实现电话号码的字母组合算法示例
2019/02/26 Javascript
关于JavaScript 数组你应该知道的事情(推荐)
2019/04/10 Javascript
微信小程序中weui用法解析
2019/10/21 Javascript
jQuery+ajax实现用户登录验证
2020/09/13 jQuery
下载给定网页上图片的方法
2014/02/18 Python
python 实现在tkinter中动态显示label图片的方法
2019/06/13 Python
python爬虫实现中英翻译词典
2019/06/25 Python
Python3的高阶函数map,reduce,filter的示例详解
2019/07/23 Python
Pytorch损失函数nn.NLLLoss2d()用法说明
2020/07/07 Python
html5中valid、invalid、required的定义
2014/02/21 HTML / CSS
日本钓鱼渔具和户外用品网上商店:naturum
2016/08/07 全球购物
解决python 输出到csv 出现多空行的情况
2021/03/24 Python
群众路线教育实践活动方案
2014/02/02 职场文书
行政管理毕业生自荐信
2014/02/24 职场文书
生产车间标语
2014/06/11 职场文书
寒山寺导游词
2015/02/03 职场文书
挂职个人工作总结
2015/03/05 职场文书
建筑工程材料员岗位职责
2015/04/11 职场文书
诚信考试主题班会
2015/08/17 职场文书
2016年教师党员公开承诺书
2016/03/24 职场文书
抖音短视频(douyin)去水印工具的实现代码
2021/03/30 Javascript
对PyTorch中inplace字段的全面理解
2021/05/22 Python
sql通过日期判断年龄函数的示例代码
2021/07/16 SQL Server