0%

11 函数作用域

函数作用域

  • 调用函数时创建的函数作用域,函数执行完毕后,函数作用域销毁
  • 每调用一次函数,就会创建一个新的函数作用域,他们之间是相互独立的
  • 在函数作用域中可以访问到全局作用域的变量
    在全局作用域中,无法访问到函数作用域的变量
  • 在函数作用域中操作一个变量,会在自身作用域中寻找
    § 如果有就直接使用,如果没有,就在上一级作用域寻找。
    § 如果全局作用域中依然没有找到,则报错ReferenceError
  • 在函数中要访问全局变量可以使用window对象。 例如window.a
1
2
3
4
5
6
7
8
var a = 10;  //创建一个变量
function fun(){
var a = "我是函数中的变量a";
var b = 20;
console.log("a = "+ a); //可以访问到外部的a
}
fun();
console.log("b = "+ b); //访问不到b
!!函数作用域也有声明提前
  • 使用var关键字声明的变量,会在函数中所有的代码执行之前被声明
  • 函数声明也会在函数中所有的代码执行之前执行
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
var c = 33;
function fun5(){
console.log(”c = ”+ c);
var c = 10; //在fun5()执行后输出undefined,因为声明提前了,但是没有赋值
c = 10; //在fun5()执行后输出33,没有声明提前,所以寻找到上一作用域的c=33
d = 100; //如果不写var,则会被认定为全局变量
}
fun5();
console.log(”d = ”+ d); //执行后输出d = 100 PS:d是函数中书写的变量
var e = 23;
function fun6(e){ //定义形参就相当于在函数作用域中声明了变量
alert(e);
}
fun6(); //执行后输出undefined,
因为声明了形参,相当于在函数中添加了var e;,但并未给e赋值
-------------本文结束感谢您的阅读-------------