位置: 编程技术 - 正文

理解javascript定时器中的setTimeout与setInterval(js定义类的三种方法)

编辑:rootadmin

推荐整理分享理解javascript定时器中的setTimeout与setInterval(js定义类的三种方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript的定义,javascript定义方法,javascript函数如何定义及其作用,javascript定律,javascript函数如何定义及其作用,javascript的理解,js定义方法的几种方式,javascript的理解,内容如对您有帮助,希望把文章链接给更多的朋友!

一、解释说明

1、概述

setTimeout:在指定的延迟时间之后调用一个函数或者执行一个代码片段

setInterval:周期性地调用一个函数(function)或者执行一段代码。

2、语法

setTimeout:

timeoutID 是该延时操作的数字ID, 此ID随后可以用来作为window.clearTimeout方法的参数 func 是你想要在delay毫秒之后执行的函数 code 在第二种语法,是指你想要在delay毫秒之后执行的代码 delay 是延迟的毫秒数 (一秒等于毫秒),函数的调用会在该延迟之后发生.但是实际的延迟时间可能会稍长一点 标准浏览器与IE支持第一种语法中向延迟函数传递额外参数的功能

setInterval

intervalID 是此重复操作的唯一辨识符,可以作为参数传给clearInterval()。 func 是你想要重复调用的函数。 code 是另一种语法的应用,是指你想要重复执行的一段字符串构成的代码 delay 是每次延迟的毫秒数 (一秒等于毫秒),函数的每次调用会在该延迟之后发生。和setTimeout一样,实际的延迟时间可能会稍长一点。 标准浏览器与IE支持第一种语法中向延迟函数传递额外参数的功能 

简单测试了下第五条,在我的电脑上面分别使用firefox与IE9测试,前者可以顺利弹出ok,后者弹出了undefined。

二、“this”问题

由setTimeout()调用的代码运行在与所在函数完全分离的执行环境上. 这会导致,这些代码中包含的 this 关键字会指向 window (全局对象)对象,这和所期望的this的值是不一样的。setInterval的情况类似。

没有被传进去,分别用chrome,firefox和IE9实验了下,都是这个结果。

解决方法一:

理解javascript定时器中的setTimeout与setInterval(js定义类的三种方法)

设置一个局部变量_this,然后放到setTimeout的函数变量中,timer执行call或apply,设置this值。

function能够调用局部变量_this,多亏了Javascript的闭包。里面涉及了作用域链等知识,有兴趣的可以自己去了解下,这里不展开了。

解决方法二:

这个方法有点高大上。自定义了setTimeout与setInterval。而且还扩展了低版本的IE浏览器,不支持向延迟函数传递额外参数的问题。

1、设置局部变量,赋值为原生的setTimeout与setInterval

2、扩展setTimeout与setInterval,aArgs通过分割arguments这个变量,获取到额外的参数数组

3、用vCallback instanceof Function判断这是不是一个函数或代码,如果是函数就用apply执行

4、setTimeout用call执行,设定this对象,以及其它的func、delay等参数

5、顺便扩展setTimeout,IE低版本的浏览器也能执行额外参数

三、setTimeout与setInterval之间的一个区别

看上去,两个功能是差不多的,但是里面其实是不一样的。

setTimeout回调函数的执行和上一次执行之间的间隔至少有ms(可能会更多,但不会少于ms)

setInterval的回调函数将尝试每隔ms执行一次,不论上次是否执行完毕,时间间隔理论上是会<=delay的。

setInterval:

从firefox的firebug可以查看到,时间间隔很不规则。

情况大致是这样的:由于count函数的执行时间远大于setInterval的定时间隔,那么定时触发线程就会源源不断的产生异步定时事件,并放到任务队列尾而不管它们是否已被处理,但一旦一个定时事件任务处理完,这些排列中的剩余定时事件就依次不间断的被执行。

setTimeout:

标签: js定义类的三种方法

本文链接地址:https://www.jiuchutong.com/biancheng/380425.html 转载请保留说明!

上一篇:Web开发必知Javascript技巧大全(javaweb开发技术有哪些)

下一篇:Bootstrap创建可折叠的组件(怎么用bootstrap搭建网站)

  • 个人独资企业是否享受六税两费政策
  • 其他权益工具影响哪些报表
  • 专票要写开户行和账号
  • 运输服务属于生产劳务吗
  • 预计净残值和残值
  • 以摊余成本计量的金融资产交易费用
  • 游戏公司收入确认方法
  • 个体户城建税优惠政策
  • 收取违约金需要什么条件
  • 所得税申报更正申报怎么报?
  • 房地产增值税怎么算抵扣土地款
  • 原材料进口关税怎么算
  • 提入转账支票会计分录
  • 火车票补票报销流程
  • 公益性支出所得税扣除比例
  • 年终对应交税费的减免税款怎样处理?
  • 超市预付款应做在哪个会计科目?
  • 小规模的企业所得税税率
  • 图文解析定期定额小规模纳税人怎么申报?
  • 个体户要申报哪些报表
  • 如何购买车辆保险
  • 进口设备不需要交关税吗
  • 总资产周转率多少算高
  • 小型微利企业能开多少发票
  • 企业所得税汇算清缴退税怎么做账务处理
  • 个人独资企业租车缴纳税金
  • 建筑劳务预缴税款后怎么申报
  • 老板请客吃饭拿餐饮发票公司报销怎么账务处理?
  • 从农民手中收购农产品增值税处理
  • 印花税减半征收优惠政策2023
  • 什么是差额征税劳务费
  • 记账凭证的摘要是什么意思
  • 存货报废会计分录例题
  • php字符串函数有哪些
  • linux 硬盘满了
  • PHP:pg_lo_open()的用法_PostgreSQL函数
  • 业绩补偿是什么意思
  • 字体文件夹在哪
  • 行政事业单位会计职责
  • 免费设备投放项目
  • Diffusion-GAN: Training GANs with Diffusion 解读
  • 现金清查的会计分录
  • 认识数据库思维导图
  • 利用python实现Apriori关联规则算法
  • 物流发票的税率怎么算
  • 完善固定资产管理的方案
  • 软件企业高新技术产品证明材料
  • 公司组织员工旅游费可以在税前扣除吗
  • 开业前需要支出什么费用
  • 房东减免后二房东不减房租
  • 职工教育经费和职工福利费扣除比例
  • 银行承兑汇票和贴现的区别
  • 进出口贸易出纳主要做什么
  • 投资损失如何入账
  • 员工借款属于什么现金流量
  • 积分兑换礼品需要什么
  • 加盖发票专用章有效什么意思
  • 对供应商的罚款需要开票吗
  • 投资主体将其拥有的货币或产业资本
  • 劳务分包需要什么条件
  • 现金流动负债比率越大越好吗
  • 生产成本的主要构成要素
  • 收到红字发票进项税怎么做账务处理
  • 将某软件添加到桌面
  • linux怎么使用ping命令
  • win7如何升级win11系统
  • linux系统编译命令
  • linux删除后恢复
  • 虚拟机安装centos7.9
  • 激活 win7
  • win10系统电脑关机自动重启
  • cocos2djs
  • div与span区别及用法
  • python中print函数的end参数
  • websocket协议解析
  • 安卓开发问题
  • js限制输入字符长度
  • JavaScript中的复杂数据类型又称为
  • jquery入门
  • 公司注销时注册资金未缴完
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设