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

javascript中闭包的概念

2017-11-22 11:12 363 查看
<html>
<head>
<title>015</title>
<script type="text/javascript" charset="utf-8">

//闭包与函数有着紧密的关系。它是函数的代码在运行过程中的一个动态环境,是一个运行期的、动态的概念
//所谓闭包,是指词法表示包括不必计算的变量的函数。也就是说,该函数能够使用函数外定义的变量
//在程序语言中,所谓闭包,是指语法域位于某个特定区域。
//具有持续参照(读写)位于该区域内自身范围之外的执行域上的非持久型变量值能力的段落。这些外部
//执行域的非持久型变量神奇地保留他们在闭包最初定义或创建的值

//定义对象,千万要记住这样定义对象,各属性之间千万要用逗号隔开,而不是分号。
//person={firstname:"John",lastname:"Doe",age:50,eyecolor:"blue"};
/*
var name="xiao A";
var obj = {
name:"xiao B",
getName:function(){
//alert(name);
//alert(this.name);//此时这个this表示obj
return function(){
return this.name;
}
}
};
obj.getName();//xiao A    xiao B
//此处注释掉alert(name)和alert(this.name);
//document.write(obj.getName());//function (){ return this.name; }
var k=obj.getName();//返回的内部匿名函数赋给变量k,k此时是全局变量,相当于直接输入obj.getName();,返回的函数都是在windows下的变量。
alert(typeof k);//function
alert(k());//xiao A
*/
/*
var name="xiao A";
var obj = {
name:"xiao B",
getName:function(){
//this总是指向调用者
var o=this;//此时指的是obj
return function(){
return o.name;
}
}
};
alert(obj.getName()());//小b
*/

//闭包:一个函数可以访问另外一个函数作用域中的变量。
//封闭性,private 起到保护变量的作用
//一级作用域
function f(x){//二级作用域
var temp=x;//局部变量   temp已经没有被使用
return function(x){//三级作用域
temp+=x;		//temp又被使用了
alert(temp);
}
}

var a=f(50);
//document.write(a);//function (x){ temp+=x; alert(temp); }

a(5);//55
a(10);//65
a(20);		//85
//相互累加的作用

</script>
</head>
<body>

</body>
</html>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息