javascript中闭包的概念

<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>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值