<script type="text/javascript">
var a=0,b=0;
function A(a){
var A = function(b){alert(a + b++)}
alert(a++);
}
A(1);
A(2);
</script>
如果这样写,显然易见为1和2,因为整个运行中并没有运行var A = function(b){alert(a + b++)}
再看:
<script type="text/javascript">
var a=0,b=0;
function A(a){
A = function(b){alert(a + b++)}
alert(a++);
}
A(1);
A(2);
</script>
结果为 1和4
因为执行A(1)时,A的作用域里并没有A,所以A = function(b){alert(a + b++)}把自己重新赋值了,并拥有之前的作用域(包括形参a)。形成了一个闭包。在调用A(2)执行的就是alert(a + b++),此时作用域中的a为2,传入的形参也是2,所以结果为4
博客分析了代码运行结果,指出执行A(1)时,A因作用域里无自身而重新赋值并形成闭包,拥有之前作用域。调用A(2)时,作用域中的a和传入形参均为2,所以结果为4。
235

被折叠的 条评论
为什么被折叠?



