/*作用域链由来:默认情况下,全局作用域成为0级链,函数可以开辟一个局部作用域,而函数内部又可以声明函数形成
新的作用域,以此类推,就形成了作用域链
变量在作用域链的访问规则:就近原则
* 当在一个作用域中访问变量时,首先在自身当前作用域寻找变量的声明,如果有声明访问的就是自身作用域的变量
如果没有声明,就在父级作用域中寻找声明,如果没有继续往父级找,一直找到顶级链,如果还没有程序就报错
*/
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<script>
/*作用域链由来:默认情况下,全局作用域成为0级链,函数可以开辟一个局部作用域,而函数内部又可以声明函数形成
新的作用域,以此类推,就形成了作用域链
变量在作用域链的访问规则:就近原则
* 当在一个作用域中访问变量时,首先在自身当前作用域寻找变量的声明,如果有声明访问的就是自身作用域的变量
如果没有声明,就在父级作用域中寻找声明,如果没有继续往父级找,一直找到顶级链,如果还没有程序就报错
*/
var num = 10;//0级链
function fn1 ( ) {//0级链,只有函数内部声明的变量才开辟局部作用域,函数本身还是全局变量
var num = 20;//1级链
console.log ( num );
function fn2 ( ) {//1级链
var num = 50;//二级链
console.log ( num );//50
}
fn2();
}
fn1();
</script>
</body>
</html>