前言,最近在做一个音频播放项目的时候,碰到播放时间精度的问题,捣鼓了几天,最终巧妙的运用定时器去降低了错误发生频率

正题,下面是对定时器的使用总结,如有错误之处,请读者加以纠正.

延迟执行(1次)

  • setTimeout

    • 定义

      • setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式。
    • 用法(不带参数函数)

      • 第一种

        • setTimeout(function () {

          }, timeout);
        • demo
          // 测试延迟执行的函数
          function Fun1() {
          alert("不带参数函数");
          } setTimeout(function(){
          Fun1();
          }, 2000);
          //或者下面这种写法
          setTimeout(() => {
          Fun1();
          }, 2000);
      • 第二种
        • setTimeout(function,timeout);
        • demo
           // 测试延迟执行的函数
          function Fun1() {
          alert("不带参数函数");
          }
          //注意这里调用的函数不加括号
          setTimeout(Fun1, 2000);
      • 第三种
        • setTimeout('function()',timeout);
        • demo
           // 测试延迟执行的函数
          function Fun1() {
          alert("不带参数函数");
          }
          //注意这里调用的函数需要加括号
          setTimeout('Fun1()',2000);
    • 用法(带参数函数)

      • 第一种

        • setTimeout(function () {codes...

          }, timeout);
        • demo
          // 测试延迟执行的函数
          function Fun2(str1,str2) {
          alert("带参数函数"+str1+str2);
          } setTimeout(function(){
          Fun2('123','456');
          }, 2000);
          //或者下面这种写法
          setTimeout(() => {
          Fun2('123','456');
          }, 2000);
      • 第二种
        • setTimeout(function,timeout,param1,param2,...);
        • demo
           // 测试延迟执行的函数
          function Fun2(str1,str2) {
          alert("带参数函数"+str1+str2);
          }
          //注意这里调用的函数不加括号
          setTimeout(Fun2, 2000,'参数1内容','参数2内容');
      • 第三种
        • setTimeout('function(param1,param2,...)',timeout);
        • demo
           // 测试延迟执行的函数
          function Fun2(str1,str2) {
          alert("带参数函数"+str1+str2);
          }
          //注意这里调用的函数需要加括号
          setTimeout('Fun2("参数1内容","参数2内容")',2000);
    • 停止定时器

      • clearTimeout(timerHandle);
      • demo
        function Fun3(str1) {
        alert(str1);
        }
        //设置定时器
        var timer=setTimeout(Fun3,2000,"参数1");
        //清除指定定时器
        clearTimeout(timer)

延迟执行(多次)

  • setTimeout

    • 定义

      • setInterval() 方法用于在间隔指定的毫秒数后调用函数或计算表达式,重复执行。
    • 跟setTimeout()用法基本一致

    • 用法(不带参数函数)

      • 第一种

        • setInterval(function () {

          }, timeout);
        • demo
          // 测试延迟执行的函数
          function Fun1() {
          alert("不带参数函数");
          } setInterval(function(){
          Fun1();
          }, 2000);
          //或者下面这种写法
          setInterval(() => {
          Fun1();
          }, 2000);
      • 第二种
        • setTimeout(function,timeout);
        • demo
           // 测试延迟执行的函数
          function Fun1() {
          alert("不带参数函数");
          }
          //注意这里调用的函数不加括号
          setInterval(Fun1, 2000);
      • 第三种
        • setInterval('function()',timeout);
        • demo
           // 测试延迟执行的函数
          function Fun1() {
          alert("不带参数函数");
          }
          //注意这里调用的函数需要加括号
          setInterval('Fun1()',2000);
    • 用法(带参数函数)

      • 第一种

        • setInterval(function () {codes...

          }, timeout);
        • demo
          // 测试延迟执行的函数
          function Fun2(str1,str2) {
          alert("带参数函数"+str1+str2);
          } setInterval(function(){
          Fun2('123','456');
          }, 2000);
          //或者下面这种写法
          setInterval(() => {
          Fun2('123','456');
          }, 2000);
      • 第二种
        • setInterval(function,timeout,param1,param2,...);
        • demo
           // 测试延迟执行的函数
          function Fun2(str1,str2) {
          alert("带参数函数"+str1+str2);
          }
          //注意这里调用的函数不加括号
          setInterval(Fun2, 2000,'参数1内容','参数2内容');
      • 第三种
        • setInterval('function(param1,param2,...)',timeout);
        • demo
           // 测试延迟执行的函数
          function Fun2(str1,str2) {
          alert("带参数函数"+str1+str2);
          }
          //注意这里调用的函数需要加括号
          setInterval('Fun2("参数1内容","参数2内容")',2000);
    • 停止定时器

      • clearInterval(timerHandle);
      • demo
        function Fun3(str1) {
        alert(str1);
        }
        //设置定时器
        var timer=setInterval(Fun3,2000,"参数1");
        //清除指定定时器
        clearInterval(timer)

js中定时器使用方法经验总结的更多相关文章

  1. js中的tostring()方法

    http://blog.sina.com.cn/s/blog_85c1dc100101bxgg.html js中的tostring()方法 (2013-11-12 11:07:43) 转载▼ 标签: ...

  2. 秒味课堂Angular js笔记------Angular js中的工具方法

    Angular js中的工具方法 angular.isArray angular.isDate angular.isDefined angular.isUndefined angular.isFunc ...

  3. JS中通过call方法实现继承

    原文:JS中通过call方法实现继承 讲解都写在注释里面了,有不对的地方请拍砖,谢谢! <html xmlns="http://www.w3.org/1999/xhtml"& ...

  4. jQuery与JS中的map()方法使用

    1.jquery中的map()方法 首先看一个简单的实例: $("p").append( $("input").map(function(){ return $ ...

  5. JavaScript -- 时光流逝(二):js中数组的方法

    JavaScript -- 知识点回顾篇(二):js中数组的方法 1. 数组 (1)定义数组,数组赋值 <script type="text/javascript"> ...

  6. ASP.NET#使用母版时,如果要使用js中的getElementById()方法取得某个内容页的元素时要注意的问题

    当使用母版,要使用js中的getElementById()方法取得某个内容页的元素时,所选取的id并不是母版中内容页的id,而是在设计内容页时设定的id例子:母版页: ...... <head ...

  7. JS与OC交互,JS中调用OC方法(获取JSContext的方式)

    最近用到JS和OC原生方法调用的问题,查了许多资料都语焉不详,自己记录一下吧,如果有误欢迎联系我指出. JS中调用OC方法有三种方式: 1.通过获取JSContext的方式直接调用OC方法 2.通过继 ...

  8. JS中split使用方法和数组中元素的删除

    JS中split使用方法和数组中元素的删除 JS中split使用方法 <script language="javascript"> function spli(){ d ...

  9. JS中的splice方法

    JS中的splice方法 定义和用法 splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目. 注释:该方法会改变原始数组(集合). 语法 arrayObject.splice(ind ...

随机推荐

  1. Android weex的集成和开发

    最近为了项目需要(实际上是为了年底KPI),领导要求用3天时间,学习并使用weex开发一个页面,说实话,压力山大.在这之前压根儿就没听说过啊,一脸懵逼 无奈之余只能Google了,惊喜的发现weex的 ...

  2. .net通过代码发送邮件

    关键代码: 需要引用命名空间: using System.Net.Mail;using System.Net; MailMessage mailObj = new MailMessage(); mai ...

  3. QT的文件查找

    https://blog.csdn.net/hustyangju/article/details/17784007 http://www.cppblog.com/biao/archive/2011/1 ...

  4. 记一次JVM调优之旅(斗争full gc)

    俗话说技多不压身,当年苦读<深入理解JVM>还专门整理了笔记,现在就用上了- 笔记 http://www.cnblogs.com/syjkfind/p/3901774.html [症状]  ...

  5. Linux账号管理和ACL

    by zjmyster version :1.2 Linux账号管理和ACL权限设置: 主要相关配置文件:/etc/passwd /etc/shadow /etc/group /etc/gshadow ...

  6. 我不 大冰2017新书pdf免费下载

    善意能消戾,善意能得缘,善意能带业往生,善意能回头是岸.善意能够帮人捕捉并建立起独特的幸福感. “我不”是一种善意坦然,也是一种善意的随缘,更是一句善意的自省. <我不>——百万级畅销书作 ...

  7. 安装Kali Linux 后需要做的 20 件事 - 51CTO.COM

    我在本文中整理出了安装一份全新的Kali Linux后总是要做的若干件事情.由于我有多台笔记本电脑和工作站,所以尽量扩大下列操作步骤的适用范围,以满足每个人的需求.这是我在安装Kali Linux后做 ...

  8. python进阶介绍(进阶1)

    转载请标明出处: http://www.cnblogs.com/why168888/p/6411664.html 本文出自:[Edwin博客园] python进阶介绍(进阶1) 1. python基础 ...

  9. [转]ubuntu下整合eclipse和javah生成jni头文件开发android的native程序

    转载自:http://blog.csdn.net/jiuyueguang/article/details/9404237 本文介绍两种利用javah命令生成jni头文件的方法,第一种为大众所知的jav ...

  10. Type Systems

    This section deals with more theoretical aspects of types. A type system is a set of rules used by a ...