防止重复发送 Ajax 请求
发布时间 - 2026-01-10 23:03:44 点击率:次要考虑并理解 success, complete, error, timeout 这些事件的区别,并注册正确的事件,一旦失误,功能将不再可用;

不可避免地比普通流程要要多注册一个 complete 事件;
恢复状态的代码很容易和不相干的代码混合在一起;
推荐用主动查询状态的方式(A、B,jQuery 为例)或工具函数的方式(C、D)来去除重复操作,并提供一些例子作为参考:
A. 独占型提交
只允许同时存在一次提交操作,并且直到本次提交完成才能进行下一次提交。
module.submit = function() {
if (this.promise_.state() === 'pending') {
return
}
return this.promise_ = $.post('/api/save')
}
B. 贪婪型提交
无限制的提交,但是以最后一次操作为准;亦即需要尽快给出最后一次操作的反馈,而前面的操作结果并不重要。
module.submit = function() {
if (this.promise_.state() === 'pending') {
this.promise_.abort()
}
// todo
}
比如某些应用的条目中,有一些进行类似「喜欢」或「不喜欢」操作的二态按钮。如果按下后不立即给出反馈,用户的目光焦点就可能在那个按钮上停顿许久;如果按下时即时切换按钮的状态,再在程序上用 abort 来实现积极的提交,这样既能提高用户体验,还能降低服务器压力,皆大欢喜。
C. 节制型提交
无论提交如何频繁,任意两次有效提交的间隔时间必定会大于或等于某一时间间隔;即以一定频率提交。
module.submit = throttle(150, function() {
// todo
})
如果客户发送每隔100毫秒发送过来10次请求,此模块将只接收其中6个(每个在时间线上距离为150毫秒)进行处理。
这也是解决查询冲突的一种可选手段,比如以知乎草稿举例,仔细观察可以发现:
编辑器的 blur 事件会立即触发保存;
保存按钮的 click 事件也会立即触发保存;
但是存在一种情况会使这两个事件在数毫秒内连续发生——当焦点在编辑器内部,并且直接去点击保存按钮——这时用 throttle 来处理是可行的。
另外还有一些事件处理会很频繁地使用 throttle,如: resize、scroll、mousemove。
D. 懒惰型提交
任意两次提交的间隔时间,必须大于一个指定时间,才会促成有效提交;即不给休息不干活。
module.submit = debounce(150, function() {
// todo
})
还是以知乎草稿举例,当在编辑器内按下 ctrl + s 时,可以手动保存草稿;如果你连按,程序会表示不理解为什么你要连按,只有等你放弃连按,它才会继续。
============
更多记忆中的例子
方式 C 和 方式 D 有时更加通用,比如这些情况:
游戏中你捡到一把威力强大的高速武器,为了防止你的子弹在屏幕上打成一条直线,可以 throttle 来控制频率;
在弹幕型游戏里,为了防止你把射击键夹住来进行无脑游戏,可以用 debounce 来控制频率;
在编译任务里,守护进程监视了某一文件夹里所有的文件(如任一文件的改变都可以触发重新编译,一次执行就需要2秒),但某种操作能够瞬间造成大量文件改变(如 git checkout),这时一个简单的 debounce 可以使编译任务只执行一次。
而方式 C 甚至可以和方式 B 组合使用,比如自动完成组件(Google 首页的搜索就是):
当用户快速输入文本时(特别是打字能手),可以 throttle keypress 事件处理函数,以指定时间间隔来提取文本域的值,然后立即进行新的查询;
当新的查询需要发送,但上一个查询还没返回结果时,可以 abort 未完成的查询,并立即发送新查询;
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# 发送ajax请求
# ajax
# 防止重复请求
# Javascript发送AJAX请求实例代码
# 详解JavaScript for循环中发送AJAX请求问题
# 防止重复发送Ajax请求的解决方案
# js与jQuery终止正在发送的ajax请求的方法
# jQuery通过Ajax向PHP服务端发送请求并返回JSON数据
# jsp+ajax发送GET请求的方法
# ie发送ajax请求返回上一次结果的解决方法
# jquery跨域请求示例分享(jquery发送ajax请求)
# jquery+ajax每秒向后台发送请求数据然后返回页面的代码
# Extjs ajax同步请求时post方式参数发送方式
# AJAX中同时发送多个请求XMLHttpRequest对象处理方法
# 按下
# 编辑器
# 才会
# 两次
# 为了防止
# 还没
# 也会
# 你要
# 还能
# 可以用
# 不喜欢
# 很容易
# 能在
# 这两个
# 亦即
# 线上
# 等你
# 就可
# 皆大欢喜
# 不相干
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
jQuery 常见小例汇总
Laravel如何优化应用性能?(缓存和优化命令)
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
高性能网站服务器配置指南:安全稳定与高效建站核心方案
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】
网站制作壁纸教程视频,电脑壁纸网站?
Laravel如何实现本地化和多语言支持?(i18n教程)
,在苏州找工作,上哪个网站比较好?
PythonWeb开发入门教程_Flask快速构建Web应用
Laravel项目怎么部署到Linux_Laravel Nginx配置详解
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
Laravel API资源类怎么用_Laravel API Resource数据转换
如何快速查询网站的真实建站时间?
Linux系统命令中screen命令详解
Python面向对象测试方法_mock解析【教程】
制作旅游网站html,怎样注册旅游网站?
Laravel用户密码怎么加密_Laravel Hash门面使用教程
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
香港网站服务器数量如何影响SEO优化效果?
Linux网络带宽限制_tc配置实践解析【教程】
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】
焦点电影公司作品,电影焦点结局是什么?
如何在阿里云香港服务器快速搭建网站?
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
Laravel如何使用Passport实现OAuth2?(完整配置步骤)
Laravel如何使用Service Container和依赖注入?(代码示例)
canvas 画布在主流浏览器中的尺寸限制详细介绍
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
太平洋网站制作公司,网络用语太平洋是什么意思?
如何在景安云服务器上绑定域名并配置虚拟主机?
如何在搬瓦工VPS快速搭建网站?
Laravel怎么清理缓存_Laravel optimize clear命令详解
如何快速启动建站代理加盟业务?
iOS UIView常见属性方法小结
Python文件流缓冲机制_IO性能解析【教程】
如何基于云服务器快速搭建网站及云盘系统?
Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】
如何在腾讯云服务器快速搭建个人网站?
Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】
C++时间戳转换成日期时间的步骤和示例代码
高防服务器租用指南:配置选择与快速部署攻略
Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】
Laravel怎么解决跨域问题_Laravel配置CORS跨域访问
香港服务器租用费用高吗?如何避免常见误区?

