JavaScript--作用域

本文介绍了JavaScript中的全局作用域和函数作用域概念,包括变量和函数在不同作用域中的行为,以及如何访问和控制变量。理解这些有助于避免命名冲突,提高代码组织效率。

作用域

指一个变量的作用的范围,在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。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值