前端面试题之JavaScript(七)

2017-09-18  本文已影响0人  庄海鑫

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


从Chrome开发者工具看出,先执行第七行代码,再执行第九行,最后执行第四行,前两个属于同步任务,最后一个属于异步任务,只有当同步任务完成后,才会执行异步任务。总之,setTimeout(fn,0)的含义是,指定某个任务在主线程最早可得的空闲时间执行,也就是说,尽可能早得执行。它在"任务队列"的尾部添加一个事件,因此要等到同步任务和"任务队列"现有的事件都处理完,才会得到执行。


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


3.实现一个节流函数

    var timer
  function hiFrequency(){
      if(timer){
          clearTimeout(timer)
      }
        timer = setTimeout(function(){
             console.log('do something')
        }, 300)
  }

  hiFrequency()
  hiFrequency()
  hiFrequency()

改造,将上面所有东西封装成一个函数

function throttle(fn, delay) {
    var timer = null
    return function(){
        clearTimeout(timer)
        timer = setTimeout(function(){ 
            fn(arguments)
        }, delay)
    }
}

function fn(){
    console.log('hello ')
}

var fn2 = throttle(fn, 1000)
fn2()
fn2()
fn2()

4.简单解释单线程、任务队列、异步执行的概念

异步

原因: f2(),f3()是同步任务,f1()是异步任务,所以后执行

function f1(callback){
    setTimeout(function(){
        //做某件事,可能很久
        console.log('别急,开始执行f1')
        for(var i=0;i< 100000;i++){

        }
        console.log('f1执行完了')

        callback()
    }, 10000);

}
function f2(){
    console.log('执行f2');
}
function f3(){
    console.log('执行f3');
}
f1(f2) //当f1执行完之后再执行 f2
f3()
回调

绑定onclick, Ajax,定时器


阮一峰单线程和任务队列

上一篇下一篇

猜你喜欢

热点阅读