作用域
指一个变量的作用的范围,在JS中,有两种作用域
1.全局作用域
----直接编写在script标签中的JS代码,都在全局作用域
----全局作用域在页面打开时创建,在页面关闭时销毁
----在全局作用域中有一个全局对象window,它代表的是一个浏览器窗口,它由浏览器创建,我们可以直接使用
----在全局作用域中,创建的变量都会作为window对象的属性保存
----在全局作用域中,创建的函数都会作为window对象的方法保存
----全局作用域中的变量都是全局变量,在页面任意的部分都可以访问的到
var a = 20;
console.log(a);
console.log(window.a);
以上两个代码效果等同。
创建的函数都会作为window对象的方法保存
function fun(){
console.log("我是fun函数");
}
fun();//与window.fun()效果相同
2.函数作用域
----调用函数时,创建函数作用域,函数执行完毕以后,函数作用域销毁
----每调用一次函数就会创建一个新的函数作用域,他们之间是互相独立的
----在函数作用域中 可以访问到全局作用域的变量
//创建一个变量
var a =10;
function fun(){
console.log("a ="+a);
}
fun();
----在全局作用域中无法访问到函数作用域的变量,结果报错
//创建一个变量
function fun(){
var b=20;
}
fun();
console.log("b ="+b);
----当在函数作用域操作一个变量时,它会现在自身作用域中寻找,如果有就自身使用,如果没有则向上一级作用域中寻找,直到找到全局作用域,如果全局作用域中依然没有找到,则会报错ReferenceError。
----在函数中要访问全局变量可以使用window对象。
-----在函数作用域也有声明提前的特性,使用var关键字声明的变量,会在函数中所有的代码执行前被声明
-----函数声明也会在函数中所有的代码执行之前执行
function fun3(){
console.log(a);
var a = 35;//类似于先声明变量a,再给a赋值。
}
fun3();
------------------------------------------------------
function fun3(){
var a;
console.log(a);
a=35;
}
fun3();
注:在局部输出变量时,如果局部没有,则会向上一级寻找,在全局输出变量时,会寻找全局变量,在函数中,不使用var声明的变量都会成为全局变量,无论局部还是全局。
定义形参就相当于在函数作用域中声明了变量,但没有赋值
function fun6(e){
alert(e);
}
fun6();
输出结果undefined。
本文介绍了JavaScript中的全局作用域和函数作用域概念,包括变量和函数在不同作用域中的行为,以及如何访问和控制变量。理解这些有助于避免命名冲突,提高代码组织效率。
522

被折叠的 条评论
为什么被折叠?



