目录
一、作用域和作用域链
二、闭包
三、无意间共享环境[可以通过闭包解决]
代码一
结果一
代码二
结果二
代码三
结果三
一、作用域和作用域链
当函数声明的时候,函数会通过内部属性[scope]来记录创建范围
二、闭包
什么是闭包:闭包是一个函数加上到创建函数的作用域的连接,闭包“关闭”了函数的自由变量。
第一句话(得到的理解):2个函数,2个函数作用域[scope]还要连接上;
第二句话(得到的理解):关闭函数的变量自由:它暂时不会销毁;
三、无意间共享环境[可以通过闭包解决]
代码一
var str = '123';function fn(){var str = '456';console.log( str );
}fn();
结果一
代码二
function fun(n){return function(m){n+=m;return n;} }//第一步
var f = fun(5);
//第二步console.log( f(1) );console.log( f(1) );console.log( f(1) );
结果二
代码三
var lis = document.getElementsByTagName('li');for(var i=0;i<lis.length;i++){(function(){var idx = i;lis[i].onclick = function(){console.log(idx);}})();}
结果三