极度重要之定时器

说到定时器,大家就肯定知道setTimeout()和setImterval(),但是他们背后还有很多更重要的知识点需要我们去掌握
首先我们重新了解一下定时器的用法
JavaScript提供了定时执行代码的功能,叫做定时器(timer),主要由setTimeout()和setInterval()这两个函数来完成,用法如下

setTimeout()

指定某个函数或者代码段,在多少毫秒内执行,会返回一个编号,编号可以用来取消这个定时器

var timer = setTimeout(func | code ,delay)
console.log(1);
setTimeout('console.log(2)',1000);
console.log(3);
//输出 1 3 2  因为setTimeout指定第二行语句推迟1000毫秒再执行

需要注意的是,推迟执行的代码必须以字符串的形式,放入setTimeout,因为引擎内部使用eval函数,将字符串转为代码。如果推迟执行的是函数,则可以直接将函数名,放入setTimeout。一方面eval函数有安全顾虑,另一方面为了便于JavaScript引擎优化代码,setTimeout方法一般总是采用函数名的形式,就像下面这样。

setTimeout(function (){console.log(2)},1000);

setInterval()

setInterval函数的用法与setTimeout完全一致,区别仅仅在于setInterval指定某个任务每隔一段时间就执行一次,也就是无限次的定时执行。

var i = 1
 var timer = setInterval(function() {
   console.log(i++);
 }, 1000);

定时器有触发就有停止


setTimeout和setInterval函数,都返回一个表示计数器编号的整数值,将该整数传入clearTimeout和clearInterval函数,就可以取消对应的定时器。

var id1 = setTimeout(f,1000);
var id2 = setInterval(f,1000);

clearTimeout(id1);  
clearInterval(id2);

1.异步
2.节流
首先我们了解一下什么是异步
我们js的运行机制,一般情况下是从上至下的执行,这就是很舒服,让人看起来也很容易理解,就比方有是一个保姆,每次做完一件事再去做一件事,那总会有一些特殊情况发生,比如说,保姆今天需要做的事是,打扫卫生,拿快递,买菜,做饭,但是这个保姆比较笨,快递小哥打电话给他的时候对他说:"麻烦你过三十分钟的时候去楼下拿一下快递,我准时到!",这个时候保姆就慌的一笔,这尼玛那个时候我事做没做完都不知道,他自然有自己的方法,对着小哥说:“那个麻烦你等一下,我需要把事情做完再去那快递,所以我一会打电话给你你在30分钟后到我楼下把”,没办法,快递小哥只能同意了。这就是异步
就是把一件事放在最后面的做,并不和其他事搀和着同时去做,一件一件的完成,等做完了再去做刚才搁下的事(拿快递)这个就是异步处理,也是单线程模型的特点,很多语言都是这个特点,比如php。
很费解,为什么说定时器很重要呢,因为定时器和我们的js异步处理是密不可分的

setTimeout('console.log(2)',0);
console.log(1);
console.log(3);

上述的代码按照正常的逻辑是输入的应该是2,1,3
但是我们运行一下,就可以看出来,我们代码运行的是 1,3,2
why


1.jpg

我们js开始渲染的时候会开辟两个空间,一个是正常执行空间,放置一般的代码段,一个是任务队列,他们会把认为耗时的,应该在后面的函数或者代码段放在任务队列里面,也就是图里面的webAPIs,DOM操作,ajax,定时器。等正常执行空间执行完成之后,再去执行任务队列里里面的任务!(就好比最后拿快递一个意思)
带着这个思想,我们再去理解一下上述代码,首先计时器代码被放置在任务队列里面,等其他两个console.log()执行完成之后再去执行定时器代码

2.节流
我们定时器中的setTimeout被使用后是每隔一段时间触发一次内部函数,我们可以使用某种暴力的手法暂时暂停setTimeout的运行,就是节流,仔细阅读下段代码

var flag;
function  f1(){
   if (flag) {
           clearTimeout(flag)
      }
 flag = setInterval(function(){
      console.log('我每隔一秒就执行,除非你调用f1函数打断我')
      },5000)
 }
f1();

这段代码的意思就是首先申明一个变量flag
申明函数在f1()函数内进行判断,如果flag变量不为空就暂停计时器,为空就触发计时器控制console.log打印内容,并调用函数f1()
但是这个时候打开控制台的时候就会发现控制台每隔五秒输出一次‘我每隔五秒就执行,除非你调用f1函数打断我',但是我们在控制台输入f1()回车的时候就会发现暂时停止打印了,但是五秒过后又出现了打印内容。这个就是函数节流
函数节流我们可以理解成用一个小手法把定时器暂时停止

举例说明:

  <input>

    docuemnt.querySelectorAll('input').addEventListener('keyup',function(){
        if(this.value === '') return
        if(this.timer) clearTimeout(this.timer)
        this.timer = setTimeout(()=>{
          console.log(this.value)
        },300)
    })    //实现一个300内输入支付不实行事件节流

           let oInput = document.querySelector('input')
                // oInput.addEventListener('input', function(e) {
                //     //如果直接每次onInput发请求,会导致性能问题
                //     console.log(e, this)
                // })

            oInput.addEventListener('input', debounce(callback, 500))

            function debounce(fn, delay) {
                let timer = null
                    // 绑定上下文this
                let self = this
                return function() {
                    let arg = arguments
                        // 每次清楚定时器
                    clearTimeout(timer)
                        // 重新打开定时器,做到只有最后一次执行了
                    timer = setTimeout(() => {
                        // 绑定this,传入参数给callback。通常我们需要事件对象就ok
                        fn.apply(this, arg)
                    }, delay)
                }
            }

            function callback(e) {
                console.log('触发', e.target.value)
            }
//世界节流  停止输出后一秒钟打印信息
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容