JS高级:作用域与作用域链

1、定义

        是一块“地盘”,一个代码段所在的区域

        是静态的(相对于上下文对象),也就是编写代码时就确定了

2、分类

        全局作用域

        函数作用域

        没有块作用域(ES6有块作用域,用{}包含的)

3、作用

        隔离变量,不同的作用域下同名变量不会有冲突

问题一共几个作用域:3个 n+1

			var a = 10,
				b = 20;

			function fn(x) {
				var a = 100,
					c = 300;
				console.log('fn', a, b, c, x);

				function bar(x) {
					var a = 1000,
						d = 400;
					console.log('bar', a, b, c, d, x);
				}
				bar(100);//bar 1000 20 300 400 100
				bar(200);//bar 1000 20 300 400 200
			}
			
			fn(10);//fn 100 20 300 10

 2、作用域与执行上下文

        1、区别

        全局作用域之外,每个函数都会创建自己的作用域,作用域在函数定义时候就已经确定了。而不是在函数调用时

        全局执行上下文环境是在全局作用域确定之后,js代码马上执行之前创建

        函数执行上下文是在调用函数时,函数体代码执行之前创建

        2、区别

                作用域是静态的,只要函数定义好了就一直存在,且不会变化

                执行上下文环境是动态的,调用函数时创建,函数调用结束时上下文环境就会被自动释放

        3、联系

        执行上下文环境(对象)是属于所在的作用域

        全局上下文环境==>全局作用域

        函数上下文环境==>对应函数的使用域

作用域链:嵌套的函数使用 构成由内向外的作用域--从内向外找变量

			var a = 1;

			function fn(x) {
				var b = 2;

				function bar() {
					var c = 3;
					console.log(a, b, c)
				}
				bar()
			}

			fn();//123

从内向外找

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值