JavaScript 高级(4)- 作用域、作用域链 - 学习进行中

作用域

变量作用域:就是一个变量可以使用的范围。
js中首先有一个最外层的作用域,全局作用域
js中可以通过函数来创建一个独立作用域,其中函数可以嵌套,所以作用域也可以嵌套
例如:

var a = 1;  // 全局变量
function foo() {
	// 变量提升:函数和变量的声明会被js的解释器放到最上面(函数声明的提升,函数体一同被提升)
	console.log(b);  // undefined,变量提升造成
	var b = 2;  // b是foo函数内部声明的变量,作用域在foo函数内部
	console.log(b);  // 2
	console.log(a);  // 1,a是全局作用域,foo函数内部可以访问
}
console.log(a);  // 1
console.log(b);  // 报错,b is not defined;b属于局部变量,在全局作用域中无法访问

作用域链

变量的查找过程,称之为变量的作用域链。

// 多级作用域
// 1级
var a = 1;
function foo() {
	// 2级
	console.log(a);  // 1
	console.log(b);  // undefined
	console.log(c); // 报错,c is not defined,变量为声明
	function foo1() {
		// 3级
		var c = 3;
		console.log(a);  // 1
		console.log(b);  // undefined
		console.log(c); // 3
	}
	foo1();
	var b = 2;
}
foo();

作用域链查找变量

1、若是在当前作用域找到变量,就不会再往上继续查找

var a = 1;
function foo() {
	var a = 2;
	console.log(a); // 2
}
foo();

2、局部作用域,变量提升

var a = 1;
function foo() {
	console.log(a); // undefined
	var a = 2;
}
foo();

3、查找上级作用域,只看函数在哪编写,不看在哪调用

var a = 1;
function foo() {
	var a = 2;
	return function() {
		// 3级
		console.log(a);  // 2
		console.log(b);  // undefined
	}
	var b = 2;
}
var fn = foo();
fn(); // 2, undefined
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值