js高级-闭包

变量作用域:全局变量和局部变量

1.函数内部可以使用全局变量

2.函数外部 不可以使用局部变量

3.当函数执行完毕,本作用域内的局部变量会销毁

什么是闭包?

闭包(closure)有权访问另一个函数作用域中变量的函数

简单理解就是,一个作用域可以访问另一个函数内部的局部变量。

//fun这个函数作用域 访问了另外一个函数fn里面的局部变量num
function fn(){
    var num = 10;
      function fun(){
        console.log(num);
      }
}

闭包的作用?

//我们fn外面的作用域可以访问fn内部的局部变量
function fn(){
    var num = 10;
      function fun(){
        console.log(num);
      }
    return fun;
}
var f = fn();
f();
//类似于
//var f = function fun(){
//      console.log(num);
//}

输出结果为10

主要作用:延伸了变量的作用范围。 

闭包的案例

1.点击li输出索引号

<ul class="nav">
    <li>榴莲</li>
    <li>臭豆腐</li>
    <li>鲱鱼罐头</li>
    <li>大猪蹄子</li>
</ul>

(1)利用动态添加属性的方式

<script>
     var lis=document.querySelector('.nav').querySelectorAll('li');
     for(var i=0;i<lis.length;i++){
          lis[i].index=i;
          lis[i].onclick=function(){
              //console.log(i);
              console.log(this.index);
    }

}
</script>

(2)利用闭包的方式得到当前的索引号

<script>
     
     for(var i=0;i<lis.length;i++){
          //利用for循环创建了4个立即执行函数
          //立即执行函数也称为小闭包,因为立即执行函数里面的任何一个函数都可以使用它的i这变量
        (function(i) {
             lis[i].onclick = function(){
                console.log(i);
             }
             
         })(i);
    }


</script>

2. 循环中的定时器  3s后打印所有li元素的内容

<script>
     var lis=document.querySelector('.nav').querySelectorAll('li');
     for(var i=0;i<lis.length;i++){
         (function(i){ 
              setTimeout(function(){
              console.log(lis[i].innerHTML);

          },3000)
         })(i);
    }


</script>

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

翘阳啦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值