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;  // 请求完成后重置状态
    }
});
相关推荐
全栈前端老曹1 分钟前
【前端路由】Vue Router 动态导入与懒加载 - 使用 () => import(‘...‘) 实现按需加载组件
前端·javascript·vue.js·性能优化·spa·vue-router·懒加载
温宇飞3 分钟前
高效的线性采样高斯模糊
javascript·webgl
POLITE317 分钟前
Leetcode 160.相交链表 JavaScript (Day 9)
javascript·leetcode·链表
Zyx200725 分钟前
构建现代 React 应用:从项目初始化到路由与数据获取
前端
大布布将军30 分钟前
☁️ 自动化交付:CI/CD 流程与云端部署
运维·前端·程序人生·ci/cd·职场和发展·node.js·自动化
LYFlied30 分钟前
Vue.js 中的 XSS 攻击防护机制详解
前端·vue.js·xss
七宝三叔36 分钟前
C#,为什么要用LINQ?
前端
七宝三叔37 分钟前
用「点外卖」的例子讲透HttpClient
前端
再睡一夏就好1 小时前
LInux线程池实战:单例模式设计与多线程安全解析
linux·运维·服务器·开发语言·javascript·c++·ecmascript
Beginner x_u1 小时前
从 Promise 到 async/await:一次把 JavaScript 异步模型讲透
javascript·ajax·promise·异步·async await