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。
作用域
最新推荐文章于 2022-06-09 18:55:55 发布