Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >js内置对象---计时器对象

js内置对象---计时器对象

原创
作者头像
IT工作者
发布于 2022-03-29 02:13:11
发布于 2022-03-29 02:13:11
2.5K00
代码可运行
举报
文章被收录于专栏:程序技术知识程序技术知识
运行总次数:0
代码可运行

js内置对象---计时器对象

一、计时器对象简介

二、一次性计时器

1. 一次性计时器的写法

2. 清除计时器

三、循环计时器

1. 一次性计时器的写法

2. 清除计时器

四、帧计时器

1. 设置兼容性

2. 移除计时器

五、把一次性计时器写成循环计时器

1. 写法

2. 移除计时器

六、三个计时器的区别

一、计时器对象简介

计时器对象分类

计时器对象分为一次性计时器,循环计时器,帧计时器(跟电脑的刷新频率有关)

二、一次性计时器

计时器的参数有string||function delay ms

ms—延迟多少毫秒后执行

1. 一次性计时器的写法

写法1

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   window.setTimeout(function(){
       console.log("常规代码");
   },1000)    

写法2

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   //可以不写前缀window
   setTimeout(function(){
       console.log("常规代码");
   },1000)

写法3

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   //函数的提前声明
   setTimeout(loop,2000);
   function loop(){
       console.log("执行");
   }

写法4

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   function loop(){
       console.log("执行");
   }

//字符串形式

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   setTimeout("loop()",2000);

2. 清除计时器

使用变量接收计时器对象

返回值是数值

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   var timer=setTimeout(function(){
       console.log("执行");
   },1000);
   console.log(timer);//1
   //清除计时器
   clearTimeout(timer);

三、循环计时器

和一次性计时器一致,只不过是循环执行。

1. 一次性计时器的写法

写法1

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   setInterval(function(){
       console.log("执行");
   },1000)

写法2

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   setInterval(loop,1000);
   function loop(){
       console.log("执行");
   }
   setInterval("loop()",1000);

2. 清除计时器

使用变量接收计时器对象

返回值是数值

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   var count=0;
   var timer;
   timer=setInterval(function(){
       count++;
       console.log(count);
       if(count>9)
       {
           console.log(timer);//1
           clearInterval(timer);
       }
   },1000)

四、帧计时器

根据屏幕的刷新频率执行的计时器,不需要设置时间。

回调函数执行次数通常是每秒60次。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   var count=0;
   loop();
   function loop(){
       count++;
       console.log(count);
       window.requestAnimationFrame(loop);
   }

1. 设置兼容性

//设置兼容性

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   var requestFrame=window.requestAnimationFrame||window.mozRequestAnimationFrame
   ||window.webkitRequestAnimationFrame ||window.msRequestAnimationFrame||function(callback){
       setTimeout(callback,1000/60);
   };
   var count=0;
   loop();
   function loop(){
       count++;
       console.log(count);
       requestFrame(loop);
   }

2. 移除计时器

//设置兼容性

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   var requestFrame=window.requestAnimationFrame||window.mozRequestAnimationFrame
   ||window.webkitRequestAnimationFrame ||window.msRequestAnimationFrame||function(callback){
       setTimeout(callback,1000/60);
   };
   var cancelFrame=window.cancelAnimationFrame||window.mozCancelAnimationFrame
   ||window.webkitCancelAnimationFrame||window.msCancelAnimationFrame||function(timer){
       clearTimeout(timer);
   };

//移除计时器

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   var timer;
   var count=0;
   loop();
   function loop(){
       count++;
       console.log(count);
       if(count>19){
           cancelFrame(loop);
           return;
       }
       timer=requestFrame(loop);
   }

五、把一次性计时器写成循环计时器

1. 写法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   var num=0;
   loop();
   function loop(){
       num++;
       console.log("输出", num);
       setTimeout(loop,1000);
   }

2. 移除计时器

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   var num=0;
   var timer;
   loop();
   function loop(){
       num++;
       console.log("输出", num);
       if(num>9){
           clearTimeout(timer);
           return;
       }
       timer=setTimeout(loop,1000);
   }

六、三个计时器的区别

一次性计时器和循环计时器在浏览器窗口失去焦点的时候还会执行。

帧计时器在浏览器窗口失去焦点的时候会自动暂停。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
selenium&appium中的三种等待方式---基于python
我们在实际使用selenium或者appium时,等待下个等待定位的元素出现,特别是web端加载的过程,都需要用到等待,而等待方式的设置是保证脚本稳定有效运行的一个非常重要的手段,在selenium中(appium通用)常用的等待分为显示等待WebDriverWait()、隐式等待implicitly_wait()、强制等待sleep()三种,下面我们就分别介绍一下这三种等待的区别
测试开发社区
2019/09/20
1.7K0
Python+Selenium笔记(十):元素等待机制
(一) 前言 突然的资源受限或网络延迟,可能导致找不到目标元素,这时测试报告会显示测试失败。这时需要一种延时机制,来使脚本的运行速度与程序的响应速度相匹配,WebDriver为这种情况提供了隐式等待和显式等待两种机制。 (二) 隐式等待 一旦设置隐式等待时间,就会作用于这个WebDriver实例的整个生命周期(对所有的元素查找都生效),设置隐式等待时间后,Webdriver会在一定时间内持续检测和搜寻DOM,以便于查找一个或多个不是立即加载成功并可用的元素。隐式等待的默认时间是0. WebDriver使用
free赖权华
2018/04/27
3K0
selenium webdriver——设置元素等待
如今大多数Web应用程序使用ajax技术,当浏览器在加载页面时,页面上的元素可能并不是同时被加载完成,这给定位元素的定位增加了困难,
周小董
2019/03/25
1.4K0
Selenium自动化测试-设置元素等待
使用sleep,需先导入time模块,import time, 然后使用time.sleep()来让程序等待多久。
可可的测试小栈
2019/11/14
1.9K0
Selenium2+python自动化38-显示等待(WebDriverWait)
前言: 在脚本中加入太多的sleep后会影响脚本的执行速度,虽然implicitly_wait()这种方法隐式等待方法随时一定程度上节省了很多时间。 但是一旦页面上某些js无法加载出来(其实界面元素经出来了),左上角那个图标一直转圈,这时候会一直等待的。 一、参数解释 1.这里主要有三个参数: class WebDriverWait(object):driver, timeout, poll_frequency 2.driver:返回浏览器的一个实例,这个不用多说 3.timeout:超时的总时长 4.po
上海-悠悠
2018/04/08
1.3K0
Selenium2+python自动化38-显示等待(WebDriverWait)
Appium Android Toast元素识别
在日常使用App过程中,经常会看到App界面有一些弹窗提示(如下图所示)这些提示元素出现后等待3秒左右就会自动消失,那么我们该如何获取这些元素文字内容呢?
清风穆云
2021/08/09
1.4K0
Appium+python自动化(二十四)- 白素贞千年等一回许仙 - 元素等待(超详解)
  许仙小时候最喜欢吃又甜又软的汤圆了,一次一颗汤圆落入西湖,被一条小白蛇衔走了。十几年后,一位身着白衣、有青衣丫鬟相伴的美丽女子与许仙相识了,她叫白娘子。白娘子聪明又善良,两个人很快走到了一起。靠着自己的力量,他们过上了幸福的生活。一天,僧人法海找到许仙,警告说白娘子是一条修行千年的蛇精,许仙不信。到了端午节,勉强喝下了雄黄酒的白娘子现了原形,许仙被吓得昏死过去。原来白娘子真的是之前吃下许仙汤圆的小蛇。白娘子辛苦救回了许仙的性命,但之后法海却以保护许仙的名义将他囚禁起来,白娘子与小青召集虾兵蟹将,要逼法海放出许仙。突然一座宝塔从天而降,把白娘子镇在了塔下…… 想必小伙伴和童鞋们都听过,或者是看过这个故事,是多么的痴情感人,尤其是千年等一回的歌曲是一个经典音乐。好了废话还是少说,进入今天的主题--元素等待   前边介绍了APP页面元素的识别定位、操作等技术,可能你会觉得掌握这两项技术就可以实施APP自动化了,答案基本是这样的,毕竟元素定位和操作是核心技术。但是,在某些场景,脚本的运行并非预期那样,如,要操作的元素用常规方法无法识别、元素可以识别但在脚本运行时却未如期而至等。为了解决这些疑难杂症,接下来内容将会介绍处理这些问题的通用方法。   在本节,主要介绍元素等待的使用方法和场景,该方法是开发稳定、高容错性自动化脚本的前提。
北京-宏哥
2019/07/30
1.3K0
Appium+python自动化(二十四)- 白素贞千年等一回许仙 - 元素等待(超详解)
Selenium自动化测试-设置元素等待
使用sleep,需先导入time模块,import time, 然后使用time.sleep()来让程序等待多久。
王大力测试进阶之路
2020/03/10
1.6K0
Selenium常用的元素等待方法
日常的UI自动化测试,单步调试的时候元素可以定位到,并且可以正常操作,但是在跑测试案例流程的时候反而报错。这时就需要考虑是否界面的切换,或者功能的跳转缓慢导致元素未加载完成就执行了操作,所以我们需要加上元素等待。WebDriver提供了几种类型的等待:强制等待、显式等待和隐式等待。
Altumn
2019/10/21
1.8K0
Selenium系列(六) - 详细解读强制等待、隐式等待、显式等待的区别和源码解读
https://www.cnblogs.com/poloyy/category/1680176.html
小菠萝测试笔记
2020/06/09
4.4K1
Appium+PythonUI自动化之webdriver的三种等待方式(强制等待、隐式等待、显示等待)
在自动化测试脚本的运行过程中,webdriver操作浏览器的时候,对于元素的定位是有一定的超时时间,大致应该在1-3秒的样子,如果这个时间内仍然定位不到元素,就会抛出异常,中止脚本执行。我们可以通过在脚本中设置等待的方式来避免由于网络延迟或浏览器卡顿导致的偶然失败,常用的等待方式有三种: 一、强制等待 time.sleep(5)
王大力测试进阶之路
2019/10/25
4K0
Appium+PythonUI自动化之webdriver的三种等待方式(强制等待、隐式等待、显示等待)
WebUI自动化测试中隐藏的元素如何操作?三种元素等待方式如何理解?
虫无涯
2023/11/14
6760
Selenium4+Python3系列(六) - Selenium的三种等待,强制等待、隐式等待、显式等待
用一句通俗易懂的话就是:等待元素已被加载完全之后,再去定位该元素,就不会出现定位失败的报错了。
软件测试君
2022/12/05
3.3K0
Selenium4+Python3系列(六) - Selenium的三种等待,强制等待、隐式等待、显式等待
Selenium 元素checkbox元素操作与元素等待
检测百度页面搜索按钮是否存在,存在就输入关键词“自学网 Selenium” 然后点击搜索
清风穆云
2021/08/09
1.7K0
Appium+python自动化(二十六)- 烟花一瞬,昙花一现 -Toast提示(超详解)
  今天宏哥在这里首先给小伙伴们和童鞋们分享一个有关昙花的小典故:话说昙花原是一位花神,她每天都开花,四季都灿烂。她还爱上了每天给她浇水除草的年轻人。后来,此事给玉帝得知。于是,玉帝大发雷霆,要拆散鸳鸯。他将花神抓了起来,把她贬为每年只能开一瞬间的昙花,不让她再和情郎相见,还把那年轻人送去灵鹫山出家,赐名韦陀,让他忘记前尘,忘记花神。   多年过去了,韦陀果真忘了花神,潜心习佛,渐有所成。而花神却怎么也忘不了那个曾经照顾她的小伙子。她知道每年暮春时分,韦陀总要下山来为佛祖采集朝露煎茶。所以,昙花就选择在那个时候开放。她把集聚了整整一年的精气绽放在那一瞬间,希望韦陀能回头看她一眼,能记起她。可是,千百年间过去了,韦陀一年年的下山来采集朝露,昙花一年年的默默绽放,韦陀始终没有记起她。直到有一天,一名枯瘦的男子从昙花身边走过,看到花神忧郁孤苦之情,便停下脚步问花神:“你为什么哀伤?”。花神惊异,因为凡人是看不到花神的真身。如果是大罗金仙头上有金光、如果是妖魔头上有黑气、如果而凡人头上是无任何灵光。刚刚从身边走过的明明是一个凡人,如何看得见自己的真身。花神犹豫片刻,只是答到:“你帮不了我”。又默默等待韦陀,不再回答那个男子的话。40年后,那个枯瘦男子又从昙花身边走过,重复问了40年前的那句话:“你为什么哀伤?”花神再次犹豫片刻,只是答道“你也许帮不了我”。枯瘦的男子笑了笑离开。再40年后,一个枯瘦的老人再次出现在花神那里,原本枯瘦的老人看起来更是奄奄一息。当年的男子已经变成老人,但是他依旧问了和80年前一样的话:“你为什么哀伤?”。昙花答道:“谢谢你这个凡人,在你一生问过我3次,但是你毕竟是凡人,而且已经奄奄一息,还怎么帮我,我是因爱而被天罚的花神”。老人笑了笑,说“我是聿明氏,我只是来了断80年前没有结果的那段缘分。花神,我只送你一句‘缘起缘灭缘终尽、花开花落花归尘’”。说完老人闭目坐下。时间渐渐过去,夕阳的最后一缕光线开始从老人的头发向眼睛划去。老人笑道:“昙花一现为韦陀,这般情缘何有错,天罚地诛我来受,苍天无眼我来开”。说罢,老人一把抓住花神。此时的夕阳正好滑到了老人的眼睛,老人随即圆寂,抓着花神一同去往佛国去。花神在佛国见到了韦陀,韦陀也终于想起来前世因缘。佛祖知道后准韦陀下凡了断未了的因缘。   昙花一现,只为韦陀。所以,昙花又名韦陀花。也因为昙花是在夕阳后见到韦陀,所以昙花都是夜间开放。   好了,到此故事结束了,开始今天的主题 - 获取toast提示 在日常使用App过程中,经常会看到App界面有一些弹窗提示(如下图所示)这些提示元素出现后等待3秒左右就会自动消失,这个和我日常生活中看到的烟花和昙花是多么的相似,那么我们该如何获取这些元素文字内容呢?
北京-宏哥
2019/08/05
1.8K0
Appium+python自动化(二十六)- 烟花一瞬,昙花一现 -Toast提示(超详解)
众里寻他千百度—Appium Android 元素定位方式
与Web自动化测试一样,App自动化测试过程中最重要一个环节就是元素定位,只有准确定位到了元素才能进行相关元素的操作,如输入、点击、拖拽、滑动等。appium提供了许多元素定位的方法,如id定位、name定位、class定位、层级定位等等.... 接下来将会给大家来实践运用这些定位技巧。
清风穆云
2021/08/09
1.1K0
selenium 的显示等待与隐式等待
现在很多的网页都采用了 Ajax 技术,那么采用一般的静态爬虫技术会出现抓取不到页面的元素。比如歌曲的主页会有评论数量,一般评论数量是动态加载的。 所以这就涉及到selenium,支持各种浏览器,包括Chrome,Safari,Firefox 等主流界面式浏览器,如果你在这些浏览器里面安装一个 Selenium 的插件,那么便可以方便地实现Web界面的测试。
张凝可
2019/08/22
3.7K0
Selenium
元素定位可以根据id,class等属性定位,也可以根据标签名等信息进行定位。使用定位函数后会返回一个WebElement类或一个WebElement类的列表,用于接下来的操作。
TomatoCool
2023/07/31
2520
「docker实战篇」python的docker爬虫技术-appium+python实战(18)
2.python在运行过程中如果进行uiautomatorviewer加载会报错 3.python在使用的过程中需要先引入 from appium import webdriver from selenium.webdriver.support.ui import WebDriverWait 4.前提是启动的appium:提示:The server is running
IT架构圈
2019/04/26
6140
「docker实战篇」python的docker爬虫技术-appium+python实战(18)
Python 爬虫(四):Selenium 框架
Selenium 是一个用于测试 Web 应用程序的框架,该框架测试直接在浏览器中运行,就像真实用户操作一样。它支持多种平台:Windows、Linux、Mac,支持多种语言:Python、Perl、PHP、C# 等,支持多种浏览器:Chrome、IE、Firefox、Safari 等。
Python小二
2020/08/18
1.2K0
Python 爬虫(四):Selenium 框架
推荐阅读
相关推荐
selenium&appium中的三种等待方式---基于python
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验