js实现定时刷新,并设置定时器上限

定时器

在js中,有两种定时器:

  1. 倒计时定时器
    倒计时定时器,也叫延时定时器或一次性定时器
    功能:倒计时多长时间后执行某个动作
    语法:setTimeout(function, timeout);
    返回值:int类型,当前定时器是页面的第几个定时器,就返回几
    执行频率:只执行一次

    var timer2 = setTimeout (function(){
    console.log("倒计时定时器执行了"); // 2秒后执行,仅执行一次
    }, 2000);

  2. 间隔定时器
    间隔定时器,也叫反复性定时器或间歇性定时器
    功能:每间隔多长时间就执行某个动作
    语法:setInterval(function, timeout);
    返回值:int类型,当前定时器是页面的第几个定时器,就返回几
    执行频率:只要不关闭,会一直执行

    var timer2 = setInterval(function(){
    console.log("间隔定时器执行了"); // 每隔2秒执行一次
    }, 2000);

  3. 实践应用
    在PC端扫码支付的时候,可以通过倒计时定时器和间隔定时器来实现对订单支付状态的感知。比起通过websocket双向通信,更简单,几行代码就可以搞定

    // 倒计时定时器,假设支付订单失效时间是5分钟,那么设置一个倒计时定时器,从发起支付后开始倒时间,超过5分钟后,支付失败,跳转到订单明细页面
    setTimeout(function () {
    window.location.href = '订单明细页面';
    }, 300000);
    // 间隔定时器,每间隔2秒查询一次订单支付状态,若订单支付成功,跳转到订单明细页面
    setInterval(function() {
    $.ajax({
    url: '查询订单支付状态',
    type: 'get',
    dataType: 'json',
    data: {order_id: order_id},
    success: function (data) {
    if (data === 1) {
    window.location.href = '订单明细页面';
    }
    }
    })
    }, 2000);

相关推荐
阿kun要赚马内几秒前
Python装饰器的原理详解
开发语言·python
kyle~1 分钟前
FANUC机械臂---R寄存器
开发语言·c++·机器人·fanuc
长沙红胖子Qt8 分钟前
Qt实用技巧:多QLabel不规则间距像素对齐文本方式实现
开发语言·qt·字符间距·动态控制
码云数智-园园9 分钟前
Go并发编程避坑指南:如何彻底消灭数据竞争(Data Race)
开发语言
程序员小寒9 分钟前
JavaScript设计模式(十):模板方法模式实现与应用
前端·javascript·设计模式·模板方法模式
Mem0rin10 分钟前
[Java/数据结构]树的基本概念、二叉树的创建和遍历
java·开发语言·数据结构
我不是懒洋洋11 分钟前
【经典题目】链表OJ(轮转数组、返回倒数第k个节点、链表的回文结构)
c语言·开发语言·数据结构·算法·链表·visual studio
We་ct12 分钟前
EventSource & WebSocket & HTTP
前端·javascript·网络·websocket·网络协议·http·面试
Lyyaoo.14 分钟前
【JAVA基础面经】CAS 与 ABA
java·开发语言
Allen_LVyingbo17 分钟前
《狄拉克符号法50讲》习题与解析(上)
开发语言·人工智能·python·数学建模·量子计算