标签:
对于闭包的理解首先需要对作用域的进行了解,其中最重要的一点是对于JS函数运行在它们被定义的作用域里而不是被执行的作用域里: function f1() {
function f1() {
var a = 1;
f2();
function f2() {
alert(a);
}
}
f1();代码一
function f1() {
var a = 1;
f2();
}
function f2() {
alert(a);
}
f1();代码二
代码一显示a=1,代码二显示a未定义。
闭包:指外部函数无法获得内部函数的值,但内部函数的下一级可以获得并返回。
一.关于this:举连个例子:
1.
function Hero(name) { this.name = name; } var h = Hero("pcd"); var h = new Hero("pcd");
不使用new时,h值为该函数的返回值,为undefined,this指向全局变量window。
但创建一个对象时,this指向这个对象。
2.
var name = "The Window";
var object = {
name: "My Object",
getNameFunc: function() {
return function() {
return this.name;
}
}
}
console.log(object.getNameFunc()());
var name = "The Window";
var object = {
name: "My Object",
getNameFunc: function() {
var that = this;
return function() {
return that.name;
}
}
}
console.log(object.getNameFunc()());
当函数被作为某个对象的方法调用时,this指向那个对象,在全局函数中this等于window。
二.
function fun(n,o) { console.log(o) return { fun:function(m){ return fun(m,n); } }; } var a = fun(0); a.fun(1); a.fun(2); a.fun(3);//undefined,?,?,? var b = fun(0).fun(1).fun(2).fun(3);//undefined,?,?,? var c = fun(0).fun(1); c.fun(2); c.fun(3);//undefined,?,?,?
答案为:
//答案: //a: undefined,0,0,0 //b: undefined,0,1,2 //c: undefined,0,1,1
题目详解链接:http://www.cnblogs.com/xxcanghai/p/4991870.html
三.模拟块级作用域
javascript内有块级作用域,例:
if(true) { var color = "blue"; } console.log(color);//blue for (var i=0; i < 5; i++){ console.log(i); } console.log(i);//5
在函数中造成在存在该值,例:
function outputNumbers(count){ for (var i=0; i < count; i++){ console.log(i); } console.log(i); //count } outputNumbers(5);
为了使outputNumbers()中的其他地方不在有i值,将其放入模拟块级作用域中
function outputNumbers(count){ (function() { for (var i=0; i < count; i++){ console.log(i); } })(); console.log(i); //错误 }
则在outputNumbers()中的其他地方不存在有i值。
四.内存泄露
标签:
原文地址:http://www.cnblogs.com/pcd12321/p/5263420.html