settimeout()停止_需求方案

settimeout()停止_需求方案转载https://aotu.io/notes/2017/09/25/manage-setTimeout-an-setInterval/在管理setTimeout&setInterval这两个APIs时,笔者通常会在顶级(全局)作用域创建一个叫 timer 的对象,在它下面有两个数组成员——{sto,siv},用它们来分别存储需要管理的setTimeoutID/…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

转载https://aotu.io/notes/2017/09/25/manage-setTimeout-an-setInterval/

在管理 setTimeout & setInterval 这两个 APIs 时,笔者通常会在顶级(全局)作用域创建一个叫 timer 的对象,在它下面有两个数组成员 —— {sto, siv},用它们来分别存储需要管理的 setTimeoutID / setIntervalID。如下:

 

1

2

3

4

 

var timer = {

sto: [],

siv: []

};

在使用 setTimeout / setInterval 的时候,这样调用:

 

1

2

3

4

5

6

7

8

 

// 标记 setTimeoutID

timer.sto.push(

setTimeout(function() {console.log(“3s”)}, 3000);

);

// 标记 setIntervalID

timer.siv.push(

setInterval(function() {console.log(“1s”)}, 1000)

);

 

在页面需要 clearTimeout \ clearInterval 的时候,这样调用:

 

1

2

3

4

 

// 批量清除 setTimeout

timer.sto.forEach(function(sto) {clearTimeout(sto)});

// 批量清除 setInterval

timer.siv.forEach(function(siv) {clearInterval(siv)});

暂停 & 恢复

近段时间,笔者发现很多业务都需要「暂停」和「恢复」setTimeout & setInterval 的功能,而仅靠原生的四个 APIs(setTimeout / setIntervale / clearTimeout / clearInterval)是不够用的。于是,笔者对 timer 进行了扩展,使它具备了「暂停」和「恢复」的功能,如下:

 

1

2

3

4

 

// 暂停所有的 setTimeout & setInterval

timer.pause();

// 恢复所有的 setTimeout & setInterval

timer.resume();

扩展后的 timer对象下面挂载6个基础的 APIs。

  • setTimeout
  • setInterval
  • clearTimeout
  • clearInterval
  • pause
  • resume

使用 timer.set* & timer.clear* 来代替原生的 set* & clear*。笔者把扩展后的 timer 托管在 GitHub 仓库上,有兴趣的同学可以移步:https://github.com/leeenx/timer

CreateJS 的启发

在使用 CreateJS 开发一些项目的过程中,笔者发现通过设置 createjs.Ticker.paused = true / false,可以暂停/恢复 createjs.Tween 上的动画。于是笔者借用 createjs.Tween 模拟了 setTimeout & setInterval 的功能,如下:

 

1

2

3

4

5

6

7

8

 

// setTimeout

createjs.setTimeout = function(fn, delay) {

createjs.Tween.get().wait(delay).call(fn);

}

//setInterval

createjs.setInterval = function(fn, delay) {

createjs.Tween.get().wait(delay).call(fn).loop = 1;

}

 

具体的代码笔者托管在:createjs.timer
其实就是在 createjs 对象下挂载四个 APIs:

  • setTimeout
  • setInterval
  • clearTimeout
  • clearInterval

使用方法与原生的 setTimeout & setInterval 一样,如下:

 

1

2

 

let siv = createjs.setInterval(() => console.log(“1s”), 1000);

createjs.setTimeout(() => createjs.clearInterval(siv), 5000);

 

时间轴驱动的 timer

createjs.timer 在 CreateJS 项目的开发给笔者带来了极大的便利,但是它必须依赖 createjs.Tween 模块。于是笔者就在思考能否创建一个跟第三方框架无关并且又可以在第三方框架上使用的 timer

createjs.Ticker.paused 为什么能暂停 createjs.Tween 上的动画的?
createjs.Tween 中每一个动画都有一条自己的时间轴,这条时间轴是通过 createjs.Ticker 来驱动的;当 createjs.Ticker 被暂停后,createjs.Tween 中的每个动画的时间轴也会失去动力而暂停下来。

createjs.Ticker 的作用是提供一个刷新 canvas 画面帧频,通常是使用 requestAnimationFrame or setInterval 来实现的。如果 timer 内部存在一条时间轴,这条时间轴由第三方驱动,那么 timer 就可以与第三方框架状态同步了。

笔者是这样设计 timer 的结构:

  • queue —— 存放 setTimeout or setInterval 的队列;
  • updateQueue —— 驱动 queue 的内部 API;
  • update —— 外部接口,用于对接第三方 Ticker。

实现的伪代码如下:

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

 

/*

@queue 成员的结构如下:

{

fn: fn, // 回调函数

type: “timeout or interval”, // 类型

elapsed: 0, // 时间轴进度

delay: delay // 目标时长

}

*/

let queue = new Map();

function updateQueue(delta) {

queue.forEach((item, id) => {

item.elapsed += delta;

if(item.elapsed >= item.delay) {

item.fn();

// 从 queue 中删除 setTimeout 成员,interval 成员继续循环

item.type === “timeout” ? delete(id) : (item.elapsed = 0);

}

});

}

// 对外接口

this.update = function(delta) {

updateQueue(delta);

}

timer 的具体实现可以参考:https://github.com/leeenx/es6-utils#timer

timer 与 CreateJS 一起使用:

 

1

2

3

4

5

6

 

// es6 代码

import timer from ‘./modules/timer’;

// 统一 ticker

createjs.Ticker.addEventListener(“tick”, function(e) {

e.paused || timer.update(e.delta);

});

 

timer 与 PIXI 一起使用:

 

1

2

3

4

5

6

 

// es6 代码

import timer from ‘./modules/timer’;

// 统一 ticker

app.ticker.add(“tick”, function() {

timer.update(app.ticker.elapsedMS);

});

 

附上 PIXI 的线上 DEMO,二维码如下:

二维码

总结

感谢阅读完本文章的读者。本文仅代表个人观点,希望能帮助到有相关问题的朋友,如果本文有不妥之处请不吝赐教。

感谢您的阅读,本文由 凹凸实验室 版权所有。如若转载,请注明出处:凹凸实验室(https://aotu.io/notes/2017/09/25/manage-setTimeout-an-setInterval/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/186524.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • ASP.NET中使用UpdatePanel实现局部异步刷新方法和攻略「建议收藏」

    ASP.NET中使用UpdatePanel实现局部异步刷新方法和攻略「建议收藏」转载自:ching126,http://blog.csdn.net/chenhongwu666/article/details/41392529asp.netUpdatePanel实现异步局部刷新如有雷同,不胜荣欣,若转载,请注明鉴于最近项目需要,研究了一下UpdatePanel控件的使用方法,现总结如下,可能有很多地方不足,还望大家斧正哦,此文的目的也是为了

  • mysql导入数据库_只用frm向mysql导入表结构

    网上一个连接mysql的jsp代码段,给了数据库的备份文件,但是只有frm,查了下资料,原来只有frm也能导入。 过程如下:1.在mysql目录下的data目录中,找到要导入表所在的数据库的名称,把frm文件放进去,比如我这里是offer.frm,数据库名称是netshop,放到数据库netshop目录下之后,在mysql中show tables显示如下在这里table是显示的,但是desc of

  • mybatis逆向工程配置文件_mybatis逆向工程多表查询

    mybatis逆向工程配置文件_mybatis逆向工程多表查询mybatis逆向工程很早之前有用过,但是一直没有整理使用步骤,今天来回顾下在idea下springboot中整合mybatis逆向工程的实现步骤什么是逆向工程?所谓mybatis逆向工程,就是mybatis会根据我们设计好的数据表,自动生成pojo、mapper以及mapper.xml。本文将介绍两种方式实现mybatis的逆向工程。generatorConfig.xml配置文件配置数据…

  • 公司里面常说的“BP”,“BU”到底是什么意思?

    在很多外企中,会经常说到一些专有名词,比如各BU,某BP。你知道这两个英文简写的含义吗?来看今天这些外企常用的表达吧。BU=BusinessUnit,业务单元一般公司里都会有不同的部门,如教育公司会有中小学事业部、外教事业部、大学生事业部、成人事业部等。对于多业务的集团性公司来说,每个部门都是一个BUSINESSUNIT,也就是独立完成一件事情的小组或部门。VolvoM…

  • c语言的fprintf函数的用法,fprintf 和fscanf 函数

    c语言的fprintf函数的用法,fprintf 和fscanf 函数C语言的fprintf和fscanf函数fprintf()函数用于将一组字符写入文件。它将格式化的输出发送到流。fprintf()函数的语法如下:intfprintf(FILE*stream,constchar*format[,argument,…])示例:创建一个源文件:fprintf-write-file.c,其代码如下-#includemain(){FILE…

    2022年10月18日
  • Ubuntu 12.10 安装JDK7

    Ubuntu 12.10 安装JDK7

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号