闭包案例产生多个相同的随机数 沙箱

闭包案例产生多个相同的随机数

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <script>
      function showRandom(){
        var num = parseInt(Math.random()*10+1);
        console.log(num);
      }

      // showRandom();
      // showRandom();
      // showRandom();

      // 闭包的方式,产生三个随机数,但是都是相同的
      function f1(){
        var num = parseInt(Math.random()*10+1);
        return function(){
            console.log(num);
            return num;
        }
      }
      var ff = f1();
      console.log(ff());
      console.log(ff());

      // 总结:如果想要缓存数据,就把这个数据放在外层的函数和里层的函数的中间位置

      // 闭包的作用:缓存数据.有点也是缺点,没有及时的释放

      // 局部变量是在函数中,函数使用结束后,局部变量就会被自动的释放
      // 闭包后,里面的局部变量的使用作用域链就会被延长

  </script>
</head>
<body>
  
</body>
</html>

沙箱

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <script>
      // 沙箱:环境,黑盒,在一个虚拟的环境中模拟真实世界,做实验,实验结果和真实结果
      // 是一样的,但是不会影响真实世界

      // var num = 10;
      // console.log(num+10);

      // 沙箱----小环境
      // (function(){
      //   var num = 10;
      //   console.log(num);
      // })();

      // // 沙箱----小环境
      // (function(){
      //   var num = 20;
      //   console.log(num+10);
      // }());

      var num = 100;
      (function(){
        var num = 10;
        console.log(num);
      }());

      console.log(num);

  </script>
</head>
<body>
  
</body>
</html>

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值