//一道极容易出错,又极基础的JS面试题
<script type="text/javascript">
var str1 = 'global';
function t1() {
console.log(str1);
console.log(str2);
//str2 = 'local';
}
t1(); //global,undefined
</script>
/*
分析:
执行时,在t1内寻找str1–没有,又在window上寻找str1,有,打印global
再执行时,在t1内寻找str2–没有,又在window上寻找str2,没找到,报undefined
而接下来的赋值语句(实际上出错) 之前没执行到那,到那才把全局的str2变量赋值
*/
<script type="text/javascript">
var str1 = 'global';
function t1() {
str2 = 'local';
console.log(str1);
console.log(str2);
}
t1(); //global,local
</script>
/*
分析:
执行log(str1)时,在t1内寻找str1–没有,又在window上寻找str1,有,打印global
执行log(str2)时,在t1内寻找str2–找到了个赋值的,但仍可打印输出
*/