美文网首页
闭包,定时器

闭包,定时器

作者: 冰哲 | 来源:发表于2016-08-17 20:14 被阅读0次

什么是闭包?

闭包是指有权访问另一个函数作用域中的变量的函数。创建闭包的常见方式就是在一个函数内部创建另一个函数。
作用是读取内部变量,这些变量可以保存在内存中。

setTimeout 0有什么作用?

其他代码执行后,立即执行setTimeout 0 的代码,
0表示延迟的时间,也可以作异步执行。

代码

下面的代码输出多少?修改代码让fnArr[i]()输出i,使用两种以上的方法。

var fnArr = [];
for (var i = 0; i < 10; i++) {
  fnArr[i] = function(){
    return i;
  };
}
console.log( fnArr[3]() );
*/

/* 方法一
var fnArr = [];
for (var i = 0; i < 10; i++) {
  (function(){
    var n = i;
    fnArr[i] = function(){
      return n;
    }
  })();
}
console.log( fnArr[3]() );
*/
/* 方法2
var fnArr = [];
for (var i = 0; i < 10; i++) {
  fnArr[i] = (function(i){
    return function(){ return i; };
  })(i);
}
console.log( fnArr[4]() );

使用闭包封装一个汽车对象,可以通过如下方式获取汽车的状态

var Car = //todo;
Car.setSpeed(30);
Car.getSpeed(); //30
Car.accrlerate();
Car.getSpeed(); //40
Car.decelerate();
Car.decelerate();
Car.getSpeed();
Car.getStatus();
Car.decelerate();
Car.decelerate();
Car.getStatus();

var Car = carSet();
function carSet(){
  var speed = 0;
  function setSpeed(num){
    speed = num;
  }
  function getSpeed(){
    console.log(speed);
  }
  function accelerate(){
    speed += 10;
  }
  function decelerate(){
    speed -= 10;
  }
  function getStatus(){
    if (speed === 0) {
      console.log("stop");
    }
    else {
      console.log("running");
    }
  }
  return {
    setSpeed:setSpeed,
    getSpeed:getSpeed,
    accelerate:accelerate,
    decelerate:decelerate,
    getStatus:getStatus
  }
}
Car.setSpeed(30);
Car.getSpeed(); //30
Car.accelerate();
Car.getSpeed(); //40
Car.decelerate();
Car.decelerate();
Car.getSpeed(); //20
Car.getStatus(); //running
Car.decelerate();
Car.decelerate();
Car.getStatus(); //stop

写一个函数使用setTimeout模拟setInterval的功能

var i =0;
function inter(){
  setTimeout(function(){console.log(i++);inter();}),1000
}

写一个函数,计算setTimeout平均最小时间粒度

var i = 0;
var start = Date.now();
function getmin(){
 var clock = setTimeout(function(){
   i++;
   if (i === 1000) {
     clearTimeout(clock);
     var end = Date.now();
     console.log((end-start)/i);
   }
   clock = setTimeout(arguments.callee,0);
 },0);
}
getmin();

下面这段代码输出结果是什么?为什么?

var a = 1;
setTimeout(function(){
  a = 2;
  console.log(a);
},0);
var a;
console.log(a);
a = 3;
console.log(a);

//输出结果:1
           3
           2
setTimeout和setInterval 的运行机制是,讲代码一处本次执行队列,执行队列都结束后,在执行
setTimeout和senInterval

下面这段代码输出的结果是?为什么?

var flag = true;
setTimeout(function(){
  flag = false;
},0)
while(flag){}
console.log(flag);

无限循环,没有输出
setTimeout被放在最后执行,while(flag)永远执行

下面代码输出?如何输出delayer:0,delayer:1...

for (var i = 0; i < 5; i++) {
  setTimeout(function(){console.log(
    "delayer:"+ i);
  },0);
  console.log(i);
}
输出:0
1
2
3
4
delayer:5 输出5次

for (var i = 0; i < 5; i++) {
  (function(){
    var n = i;
    setTimeout(function(){console.log(
      "delayer:"+ n);
    },0);
    console.log(i);
  })();
}

相关文章

  • 前端(数组,闭包,定时器)

    数组 定时器 定时器弹框 定时器的基本用法 定时器动画 闭包 闭包存循环的索引值 闭包做私有变量计数器 闭包做选项卡

  • 前端基础(问答15)

    keywords: 闭包、定时器。 什么是闭包? 有什么作用 内层函数调用外层函数的变量,该内层函数即为闭包。本质...

  • 2018-12-08

    定时器的基本用法 定时器动画 时钟 倒计时 变量的作用域 封闭函数 用变量的方式定义函数 闭包 闭包存循环的索引值

  • 前端(十四)

    1.循环语句 2.数组去重 3.字符串反转 4.定时器的基本用法 5.定时器动画 6.时钟 7.闭包 8.闭包存循...

  • 闭包、定时器

    下面的代码输出多少?修改代码让 fnArri 输出 i。使用 两种以上的方法 方法一: 方法二: 封装一个汽车对象...

  • 闭包_定时器

    闭包的作用是:暴露局部函数立即执行函数 ==> 闭包 下面的代码输出多少?修改代码让 fnArri 输出 i。使用...

  • 闭包,定时器

    问答 什么是闭包? 有什么作用 闭包就是能够读取其他函数内部变量的函数。由于在JavaScript语言中,只有函数...

  • 闭包、定时器

    问题 一、什么是闭包(closure)? 有什么作用 ** 闭包概念** 简而言之,闭包就是有权访问另一个函数内部...

  • 定时器、闭包

    1、修改代码让 fnArr [i] () 输出 i 方法一: 方法二: 方法三: 2、封装一个汽车对象,可以通过如...

  • 闭包、定时器

    问题 什么是闭包? 有什么作用 MDN:闭包是指能够访问自由变量的函数(变量在本地使用,但在闭包中定义)。换句话说...

网友评论

      本文标题:闭包,定时器

      本文链接:https://www.haomeiwen.com/subject/tlomsttx.html