Scope is one of the foundational aspects of the JavaScript language, and probably the one I’ve struggled with the most when building complex programs. I can’t count the number of times I’ve lost track of what the this keyword refers to after passing control around from function to function, and I’ve often found myself contorting my code in all sorts of confusing ways, trying to retain some semblance of sanity in my understanding of which variables were accessible where.
要学会JavaScript,必须得先去理解它的作用域是怎样的。
没有块级作用域
JavaScript变量的作用域只有全局和局部作用域。全局作用域是定义在JavaScript中(非函数体内),可以在任何地方改变它的值,这是非常危险的。局部作用域是定义在函数体内的,它的作用域是该函数的范围。外界不能访问他,只允许函数内部访问。JavaScript的变量没有块级作用域。
var g = "G";
function F() {
alert(g); //显示G
if ( true ) {
var num = 10;
}
alert(num); //显示10
}
F();
alert(num + "1");//显示错误,num没有定义
我们再看一个例子
var p = "G";
function F2() {
alert(p);//undefined
var p = "L";
alert(p);//L
}
F2();
为什么会这样呢?我们看一张图(画不好图-_-!)。这就它查找变量的方式。
词法作用域
JavaScript函数的作用域是通过词法来划分作用域。也就是说函数是定义在函数时的那个作用域里运行的。每定义一个函数,那么JavaScript解析器就保存了该函数的作用域链了。执行该函数时,它就跑到定义那函数的地方去运行,也可以理解成引用。我们先看一个例子。
function F4() {
var a = 10;
function F5() {
return a;
}
alert(F5());//10
}
F4();
当运行F4()时,它跑到function F4的地方,然后一行一行执行下来,定义a = 10;定一个function F5;运行alert(F5()),它先在F5函数体内找a的值,找不到,再向上一层,在F4体内查找a,找到了,那么alert 10出来(如果没有找到,那么再向上,找到全局时,还没有找到,那么就是没有定义)。
垃圾回收机制与闭包
JavaScript采用自动回收,也就是当一个对象没有对其他引用的时候,那么销毁它。这很好理解,那闭包很难用专业词汇解释。其实也很容易理解。函数一 被 A 引用,函数一 体内的 函数二 又被 B 引用,那么当A引用完毕后,函数一也该销毁了,但不是这样的,它体内的函数二被B引用着,所以函数一没有被销毁,这些综合体我们叫他闭包。(解释的不好,建议找些专业的解释理解一下。)这是一种很强大的技术,理解了作用域和垃圾回收机制,这也很好理解了。在浏览器里,所有用户定义的函数都是闭包,但像上述中的函数二被第三者引用,这种闭包才有意思。
一个闭包的例子


你好可怜,都没有人给你留言! 不过JS我正在学! 呵呵 以后多交流 博客也要继续更新哦!