首页 > 代码库 > 作用域
作用域
js中变量分为两种,一种是全局变量,一种是局部变量
浏览器的js解析器对于script内部的内容分为两步
1、预解析:找一些东西,如变量var、函数function、参数,所有的变量在执行代码之前都是undefined,所有的函数在执行代码之前都是函数块
遇到重名的则只留下一个,变量和函数重名了,则只留下函数2、逐行解读代码
表达式 可以修改预解析的值
函数调用
预解析
逐行解读代码
看个例子 demo1
alert(a); // function a(){alert(4)}var a =1; alert(a); // 1function a() { alert(2);};alert(a); // 1var a = 3;alert(a); // 3function a() { alert(4);};alert(a); // 3
a() // 报错
demo2
script 全局变量 全局函数
<script> alert(a); // 报错</script><script> var a = 1;</script>
// 由上至下依次执行
demo3
<script> var a = 1; function fn1() { alert(a); // undefined; var a =2; } fn1();
alert(a); // 1</script><script> var a = 1; function fn1() { alert(a); // 1; 预解析没有找到,会执行逐行解读代码,会顺着作用域链 由里到外 往父级作用域找 a =2; // 修改了父级作用域的值 } fn1();
alert(a); // 2</script>
<script> var a = 1; function fn1(a) { alert(a); // 参数a 类似于 (var a;) 所以 为undefined a =2; // 修改了本级作用域的值,只能修改内部的值 } fn1(); // 注意此处没有传递参数
alert(a); // 1</script>
作用域
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。