JavaScript作用域----全局作用域、函数作用域

作用域是指一个变量的作用范围,在JS中一共有两种作用域:全局作用域和函数作用域(整体与局部的关系)。

全局作用域

  • 直接编写在script标签中的Js代码都是全局作用域
    例:
<script type="text/javascript">
	var a = 1;
	var b = 2;
	var c = 3;
</script>

例子中变量a、b、c都是全局作用域

  • 全局作用域在页面打开时创建,在页面关闭时销毁
  • 在全局作用域中有一个全局对象window,它代表的是一个浏览器的窗口,它由浏览器创建,我们可以直接使用。
    例1:
<script type="text/javascript">
	console.log(window);
</script>

运行结果:
在这里插入图片描述
我们会发现它确实存在一个window对象,那么我们怎么使用window对象呢?
例2:

<script type="text/javascript">
	var a = 123;
	console.log(window.a);
</script>

运行结果:
在这里插入图片描述

  • 在全局作用域中,创建的变量都会作为window对象的属性保存(例如上面的例2)。创建的函数都会作为window对象的方法保存)如下例3所示。
    例3:
<script type="text/javascript">
	window.alert("hello")
</script>

运行结果:
在这里插入图片描述

  • 全局作用域中的变量都是全局变量,在页面的任意的部分都可以访问的到。

函数作用域

  1. 全局作用域相当于是一个大的整体,而函数作用域相当于是大的整体里面的小的部分。调用函数时创建函数作用域,函数执行完毕以后,函数作用域销毁。
  2. 每调用一次函数就会创建一个新的函数作用域,他们之间时相互独立的(例如我调用了3个函数,相当于有三个函数作用域,他们三个是相互独立的)。
  3. 在函数作用域中,可以访问到全局作用域的变量(全局变量就是在任何位置都可以访问到)。
    例1:
<script type="text/javascript">
	var a = 10;
	function fun() {
		console.log("a = " + a );
	}
	fun();
</script>

运行结果:
在这里插入图片描述

  1. 在全局作用域中无法访问到函数作用域的变量
    例2:
<script type="text/javascript">
	var a = 10;
	function fun() {
		var b = 20;
		console.log("a = " + a );
	}
	fun();
	console.log("b = " + b);
</script>

运行结果:
在这里插入图片描述

  1. 当在函数作用域操作一个变量时,它会先在自身作用域中寻找,如果有就直接使用,如果没有则向上一级作用域中寻找(就近原则),直到找到全局作用域,如果全局作用域中依然没有找到,则会报错ReferenceError(引用错误)。

例3:

<script type="text/javascript">
	var a = 10;
	function fun() {
		var a = "我是函数里面的a";
		console.log("a = " + a );
	}
	fun();
	console.log("a = " + a );
</script>

运行结果:
在这里插入图片描述
例4:

<script type="text/javascript">
	var a = 10;
	function fun() {
		var a = "我是fun函数里面的a";
		function fun2(){
			console.log("a = " + a);
		}
		fun2();
	}
	fun();
</script>

运行结果:
在这里插入图片描述
如果将var a = “我是fun函数里面的a”;注释,则输出的是a = 10;因为在调用函数fun2();时,自身的作用域中没有变量a,于是往上一级函数fun();找,也没有变量a,于是再往上一级找,则找到全局作用域中的变量a = 10;则输出。

  1. 在函数中要访问全局变量可以使用window对象。
    例5:
<script type="text/javascript">
	var a = 10;
	function fun() {
		var a = "我是fun函数里面的a";
		function fun2(){
			console.log("a = " + window.a);
		}
		fun2();
	}
	fun();
</script>

运行结果:
在这里插入图片描述

  1. 在函数作用域中也有声明提前的特性,使用var关键字声明的变量,会在函数中所有的代码执行前被声明(声明提前大家不太熟悉或者忘记的可以看一下我的前一篇博客JS中变量的声明提前和函数的声明提前)函数声明也会在函数中所有的代码之前执行.
  • 在函数中,不使用var声明的变量都会变成为全局变量。
    例6:
<script type="text/javascript">
	var a = 30;
	function fun() {
		a = 20;
		b = 100;//相当于window.d = 100;是一个全局变量
	}
	fun(); 
	console.log("a = " + a);
	console.log("b = " + b);
</script>

运行结果:
在这里插入图片描述

  1. 定义形参就相当于在函数作用域中声明了变量

今天的内容有点多,但是比较详细~大家要耐心的看完噢,如果有错的地方欢迎大家指出噢!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是只胖阿拉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值