全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

防止重复发送 Ajax 请求

要考虑并理解 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对象处理方法  # 按下  # 编辑器  # 才会  # 两次  # 为了防止  # 还没  # 也会  # 你要  # 还能  # 可以用  # 不喜欢  # 很容易  # 能在  # 这两个  # 亦即  # 线上  # 等你  # 就可  # 皆大欢喜  # 不相干 


相关文章: 整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?  c# 在ASP.NET Core中管理和取消后台任务  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  如何通过.red域名打造高辨识度品牌网站?  如何用5美元大硬盘VPS安全高效搭建个人网站?  建站之星2.7模板:企业网站建设与h5定制设计专题  佛山企业网站制作公司有哪些,沟通100网上服务官网?  建站主机CVM配置优化、SEO策略与性能提升指南  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  三星网站视频制作教程下载,三星w23网页如何全屏?  道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?  建站主机与虚拟主机有何区别?如何选择最优方案?  宝华建站服务条款解析:五站合一功能与SEO优化设置指南  黑客入侵网站服务器的常见手法有哪些?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  如何用PHP快速搭建高效网站?分步指南  如何快速上传建站程序避免常见错误?  ,在苏州找工作,上哪个网站比较好?  宿州网站制作公司兴策,安徽省低保查询网站?  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  北京的网站制作公司有哪些,哪个视频网站最好?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  建站之星后台密码如何安全设置与找回?  建站之星下载版如何获取与安装?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  网站制作壁纸教程视频,电脑壁纸网站?  宝塔面板创建网站无法访问?如何快速排查修复?  简易网站制作视频教程,使用记事本编写一个简单的网页html文件?  如何通过服务器快速搭建网站?完整步骤解析  建站之星安装模板失败:服务器环境不兼容?  如何在阿里云服务器自主搭建网站?  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  建站主机核心功能解析:服务器选择与网站搭建流程指南  深圳网站制作培训,深圳哪些招聘网站比较好?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  如何在IIS中新建站点并配置端口与IP地址?  教程网站设计制作软件,怎么创建自己的一个网站?  网站制作需要会哪些技术,建立一个网站要花费多少?  建站之星ASP如何实现CMS高效搭建与安全管理?  如何选择靠谱的建站公司加盟品牌?  Thinkphp 中 distinct 的用法解析  如何用VPS主机快速搭建个人网站?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  建站DNS解析失败?如何正确配置域名服务器?  如何在Ubuntu系统下快速搭建WordPress个人网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。