js闭包的简单理解
2016-07-05 22:45
260 查看
闭包与函数有着紧密的关系,它是函数的代码在运行过程中的一个动态环境,是一个运行期的、动态的概念。
所谓闭包,是指词法表示包括不必计算的变量的函数。也就是说,该函数能够使用函数外定义的变量.。
在程序语言中,所谓闭包,是指语法域位于某个特定的区域,具有持续参照(读写)位于该区域内自身范围之外的执行域上的非持久型变量值能力的段落。这些外部执行域的非持久型变量神奇地保留他们在闭包最初定义(或创建)时的值。
var a = 'xiao A';
var obj = {
a : 'xiao B',
getName : function(){
return function(){
return this.a;
}
}
}
console.log(obj.getName()());
//闭包的基本用法
var name = 'xiao A';
var obj = {
name : 'xiao B',
getName : function(){
//this总是指向调用者
var o = this;
return function(){
return o.name;
}
}
}
console.log(obj.getName()());
//闭包最简单的理解就是:一个函数,可以访问另外一个函数的作用域
//封闭性:类似于java private起到一个保护作用
function f(x){
var temp = x; //局部变量,temp已经没有被使用
return function(x){
temp += x; //又被调用
console.log(temp);
}
}
var a = f(10);
a(5);
a(10);
a(20);
所谓闭包,是指词法表示包括不必计算的变量的函数。也就是说,该函数能够使用函数外定义的变量.。
在程序语言中,所谓闭包,是指语法域位于某个特定的区域,具有持续参照(读写)位于该区域内自身范围之外的执行域上的非持久型变量值能力的段落。这些外部执行域的非持久型变量神奇地保留他们在闭包最初定义(或创建)时的值。
var a = 'xiao A';
var obj = {
a : 'xiao B',
getName : function(){
return function(){
return this.a;
}
}
}
console.log(obj.getName()());
//闭包的基本用法
var name = 'xiao A';
var obj = {
name : 'xiao B',
getName : function(){
//this总是指向调用者
var o = this;
return function(){
return o.name;
}
}
}
console.log(obj.getName()());
//闭包最简单的理解就是:一个函数,可以访问另外一个函数的作用域
//封闭性:类似于java private起到一个保护作用
function f(x){
var temp = x; //局部变量,temp已经没有被使用
return function(x){
temp += x; //又被调用
console.log(temp);
}
}
var a = f(10);
a(5);
a(10);
a(20);
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享