Ajax 解决回调竞争

回调的竞争,即多次快速点击同一按钮导致多个异步的AJAX请求同时返回,导致数据更新顺序混乱。这种情况在异步编程中很常见,特别是前端开发时,AJAX请求的回调并不保证按顺序执行。

$.ajaxSetup() 可以设置全局的 beforeSendcomplete 回调函数,这样每个 AJAX 请求在发送前和完成后都可以执行相应的逻辑。

复制代码
let isRequestPending = false;

$.ajaxSetup({
    beforeSend: function(jqXHR, settings) {
        if (isRequestPending) {
            jqXHR.abort();  // 如果有请求正在进行,取消当前请求
            return false;    // 阻止请求发送
        }
        isRequestPending = true;  // 设置请求进行中的状态
    },
    complete: function() {
        isRequestPending = false;  // 请求完成后重置状态
    }
});
相关推荐
NotFound4869 分钟前
探究分享从对话到执行:OpenTiny NEXT 如何重塑前端智能化开发范式
前端
小满zs1 小时前
Next.js精通SEO第二章(robots.txt + sitemap.xml)
前端·seo
kyriewen1 小时前
你的首屏慢得像蜗牛?这6招让页面“秒开”
前端·面试·性能优化
算是难了1 小时前
Nestjs学习总结_3
前端·typescript·node.js
yogalin19932 小时前
如何实现一个简化的响应式系统
前端
kyriewen112 小时前
项目做了一半想重写?这套前端架构让你少走3年弯路
前端·javascript·chrome·架构·ecmascript·html5
HashTang2 小时前
我用 Cloudflare Workers + GitHub Actions 做了个 2.5 刀/月的 AI 日报,代码开源了
前端·ai编程·aiops
老王以为2 小时前
前端重生之 - 前端视角下的 Python
前端·后端·python
饭后一颗花生米2 小时前
2026 AI加持下前端学习路线:从入门到进阶,高效突破核心竞争力
前端·人工智能·学习