Js闭包与循环

目标:点击任何一个li,提示当前点击位置


<ul> <li>第1个</li> <li>第2个</li> <li>第3个</li> <li>第4个</li> <li>第5个</li> </ul> <script> var li = document.getElementsByTagName('li'); for (var i = 0; i< li.length; i++){ li[i].onclick = function(){ alert("[2]:"+i); // [2] }
alert("[1]:"+i) // [1] } </script>

1、先执行[1]位置,弹出5次警示框从0到4,执行的是for语句,i 在for内部已经变为5

2、li[i],是获取的li的HTMLCollection对象,i[i]相当于li.item(i)

3、为li[i]绑定事件,li[i].onclick 。实际上此时执行的匿名函数动态绑定的li[i],但是匿名函数是在全局中挂起(我将它理解为调用另一个函数),点击任何li弹出框都报出数字5。

修改成闭包:

    <script>
        var li = document.getElementsByTagName('li');
        for (var i = 0; i< li.length; i++){

            li[i].onclick = (function(num){
                return function(){alert(num);}
            })(i);

        }
    </script>

每一个li[i],单独调用闭包后的函数,可以理解为每个li[i]单独传值制造函数。

理解闭包:

1. 视为正在执行新函数绑定在数据链上的函数,因此如果直接调用内部函数则会报错。(从新生成占用内存,因此谨慎使用)

var foo = {
   baz: 1,
   bar: function() {             
      return (function(that){
          return that.baz;
      })(this)
   }
};
console.log( foo.bar() ) // 1

2.闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便。

3.闭包的执行。

var f = (
    function f(){ return "1"; },
    function g(){ return 2; }
)();
typeof f; // "number"

类似于

function f(){
   function f(){
      var a = 1;
      return a;
   };
   function g(){
      var b =2;
      return b;
   }
   return LastOne() // lastone 代表最后执行的函数
};
console.log(f());

相关知识点:

1.作用域:

外部不能调用局部变量。但是可以通过返回函数这种变通的方法调用到局部变量

function f1(){
    n=999;
    function f2(){
      alert(n);
    }
    return f2;
  }
  var result=f1();
  result(); // 999 ,如果调用result会返回function f2()这个函数,加()代表执行
原文地址:https://www.cnblogs.com/dongcheck/p/4548938.html