ThinkChat🤖让你学习和工作更高效,注册即送10W Token,即刻开启你的AI之旅 广告
**js的变量和其他语言的变量作用域,有很多相同的地方,但也有很多不相同的地方。尤其是变量提升这个概念。之前还真没听说过这个概念。** **先看具体的例子:** ~~~ function test2(){ alert(t); var t="123" alert(t); } ~~~ 按照之前的理解,第一个alert就应该出错。可是在谷歌浏览器已测试,没有错误。第一次弹出来的是undefined!!第二次是123,和一般语言里是一样的。 没有错误,说明t这个变量已经定义,那是不是全局变量呢? ~~~ function test(){ alert(t); var t="123" alert(t); testGlobel(); } function testGlobel(){ alert(t); } ~~~ 前两次和之前的一样,最后一次Uncaught ReferenceError: t is not defined,显然不是全局变量。 其实这就是变量提升,我的理解是,在函数中使用的任何局部变量,编译器都会把这些变量放在函数的入口处定义,但赋值还是和编写代码时是一样的,也就是说,局部变量的定义其实是在函数入口处,和我们实际编写代码的位置没有关系。赋值才真正的和我们编写代码的位置有关系。 **例如上边的代码可以改写成:** ~~~ function test(){ var t ; alert(t); t="123" alert(t); testGlobel(); } ~~~ 测试最常用的循环计数器和上边的结果是一样的,第一次是undefined!第二次是3是循环后的值,第三次是Uncaught  ReferenceError: i is not defined,显然不是全局变量。 ~~~ function test(){ alert(i); var arr=[4,2,6]; for(var i=0;i<arr.length;i++) { } alert(i); testGlobel(); } function testGlobel(){ alert(i); } ~~~ 这个或许才是和其他语言变量作用域的最大区别吧。