JavaScript作用域

JavaScript作用域:就是代码名字(变量)在某个范围内其作用和效果,目的是为了提高程序的可靠性更重要的是减少命名冲突。
js的作用域(es6)之前:全局作用域、局部作用域
全局作用域:整个script标签或者是单独的js文件

var num = 10;

局部作用域 在函数内部就是局部作用域,代码的名字只在函数内部起效果和作用

function fn(){
	//局部作用域
	var num = 20;
	
}

变量的作用域
根据作用域的不同变量分为全局变量和局部变量
1、全部变量:全局作用域下的变量,在全局下都可以使用

var num = 10;   //num就是一个全局变量
console.log(num);    //输出结果为10
function fn(){
	console.log(num);
}
fn();   //输出结果为10;

2、局部变量:局部作用域下的变量,在函数内部的变量就是局部变量,外部不能调用

function fun(){
	var num1 = 10;   //num1就是局部变量,只能在函数内部使用
}
fun();
console.log(num1)   //输出结果为  num1 is not defined

注意:
● 如果在函数内部没有使用var声明直接赋值的变量也属于全局变量(不建议使用)
● 函数的形参也可以看做是局部变量
全局变量和局部变量的区别
● 全局变量:在任何一个地方都可以使用,只有在浏览器关闭时才会被销毁,因此比较占内存
● 局部变量:只在函数内部使用,当其所在的代码块执行时,会被初始化;当代码块运行结束后,会被销毁,因此更节省内存空间。
作用域
现阶段没有块级作用域(es6之前),js在es6的时候新增了会计作用域,块级作用域{},if{}、for{}。
作用域链
● 只要是代码,就至少有一个作用域
● 写在函数内部的局部作用域
● 如果函数中有函数,那么在这个作用域中就又可以诞生一个作用域
● 根据在内部函数可以访问外部函数变量的这种机制,用链式查找决定哪些数据能被内部函数访问,就称为作用域链

var num = 10;
function fn(){
	var num = 20;
	function fun(){
		//内部函数
	}
}

作用域链:内部函数访问外部函数的变量,采取的是链式查找的方式来决定取那个值,这种结构我们称为作用域链(取值为就近原则)。

function f1(){
	var num = 123;
	function f2(){
		console.log(num);    //站在目标出发,一层一层的往外查找,根据取值的就近原则,输出结果为123
	}
}
var num = 456;
f1();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值