作用域

1,函数能封闭住定义域
一个变量如果定义在了function里面,那么这个变量就是一个局部变量,只在function里面有定义。出了这个function,就如同没有定义一样了。
function fn(){
		var a = 1;//定义在一个函数里面,局部变量,只有在函数里面有定义。
		console.log("我是函数里面的语句,我认识a值为" + a);
}
fn();
console.log("我是函数外面的语句,我不认识a" + a);
JavaScript变量作用域没有块级作用域,管理住作用域的只有一个东西:函数。
var a = 1;//定义在全局范围内的一个变量,全局变量,在程序任何一个角落都有定义。
var a = 1;
function fn(){
		console.log("我是函数里面的语句,我认识a值为" + a);
}
fn();
console.log("函数外面的语句也认识a" + a);
总结一下:定义在function里面的变量,叫做局部变量,只在function里面有定义,出来function就没有定义了。
定义在全局范围内的没有写在任何function里面的,叫做全局变量,都认识。
2,作用域链
当遇见一个变量时,JS引擎会从其所在的作用域一次向外层查找,查找会在第一个匹配的表示符的时候停止。
function outer(){
		var a = 1;//a的作用域就是outer
		inner();
		function inner(){
				var b = 2;//b的作用域就是inner
				console.log(a);// 能够正常输出1,a在本层没有定义,就去上层找
				console.log(b);//能够正常输出2
		}
}
outer();
console.log(a);//报错,因为a的作用域outer
多层嵌套,如果有同名的变量,那么就会发生“遮蔽效应”。
3,不写var就自动成全局变量了
function fn(){
		a = 1;//这个a赋值的时候,并没有var过,所以就自动的在全局的范围帮你var了一次。	
}
fn();
console.log(a);
这是JS的一个机理,如果遇见了一个标识符,从来没有var过并且还赋值了:
absdf = 123;
那么就会自动帮你在全局范围内定义一个var absdf;
所以说变量要老老实实写var。
4,函数的参数,会默认定义为这个函数的局部变量
function fn(a,b,c,d){
}
a,b,c,d就是一个fn内部的局部变量,出了fn就没有定义了。
5,全局变量的作用
全局变量有两个作用:
一、通讯,共同操作同一个变量。两个函数同时操作同一个变量,一个增加,一个减少,函数和函数通讯。
var num = 0;
function add(){
	  num++;
}
function remove(){
		num--;	
}
二、累加,重复调用函数的时候,不会重置。
var num = 0;
function baoshu(){
		num++;
		console.log(num);
}
baoshu();//1
baoshu();//2
baoshu();//3
如果num定义在baoshu里面,每次执行函数就会把num重置为0。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值