您的位置:首页 > Web前端 > JavaScript

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);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  javascript