0

0

如何解决 jQuery 中 AJAX 请求被重复触发的问题

碧海醫心

碧海醫心

发布时间:2026-02-13 08:59:57

|

836人浏览过

|

来源于php中文网

原创

如何解决 jQuery 中 AJAX 请求被重复触发的问题

本文详解 jquery 事件委托中因重复绑定导致的 ajax 多次调用问题,提供 `off()` 解绑方案、防重复提交实践及完整修复代码,确保按钮点击仅触发一次请求。

在使用 jQuery 进行 AJAX 开发时,一个常见却隐蔽的问题是:用户仅点击一次按钮,但后端却收到多次请求。这种现象并非后端逻辑错误,而往往源于前端事件监听器的重复注册——尤其在动态渲染组件(如 Laravel Blade 中嵌套的自定义组件)或多次加载同一段 JS 脚本的场景下极易发生。

在你提供的代码中,关键问题出在这一行:

$('body').on('click', '#saveaudios', function (e) { ... });

该语句使用事件委托将 #saveaudios 按钮的点击事件绑定到

上。看似合理,但若包含此脚本的 Blade 模板被多次渲染(例如通过 Livewire 重载、AJAX 局部刷新、或组件重复引入),$(document).ready() 就会被反复执行,从而导致 on('click', ...) 被多次调用——最终 上累积了多个相同的事件监听器。一旦用户点击 #saveaudios,所有监听器同步触发,AJAX 自然发送多次。

根本解决方案:注册前先解绑

Wordware
Wordware

Wordware是一个自然语言编程工具,使任何人都可以开发、迭代和部署有用的AI应用程序。

下载

使用 .off() 显式移除已存在的同类型事件监听器,再重新绑定:

$(document).ready(function () {
    // ✅ 安全绑定:先解绑,再绑定
    $('body').off('click', '#addAudio').on('click', '#addAudio', function (e) {
        e.preventDefault();
        const $this = $(this);
        const textId = $this.data('text-id');
        const webinarId = $this.data('webinar-id');

        let add_audio_modal = '<form id="addAudioFiles" method="post" action="/panel/text-lesson/saveaudio" enctype="multipart/form-data">';
        add_audio_modal += '@csrf';
        add_audio_modal += $('#audioFilesModal').html();
        add_audio_modal += '</form>'; // ⚠️ 注意:原文缺少闭合标签,已修正

        Swal.fire({
            html: add_audio_modal,
            showCancelButton: false,
            showConfirmButton: false,
            customClass: { content: 'p-0 text-left' },
            width: '48rem',
        });
    });

    // ✅ 关键修复:防止重复绑定
    $('body').off('click', '#saveaudios').on('click', '#saveaudios', function (e) {
        e.preventDefault();
        const $this = $(this);
        const form = $('#addAudioFiles');

        // ✅ 防重复提交:禁用按钮 + 添加 loading 状态
        $this.addClass('loadingbar gray').prop('disabled', true);

        const formData = new FormData(form[0]);
        formData.append('webinar_id', $this.data('webinar-id'));
        formData.append('text_id', $this.data('text-id'));

        $.ajax({
            url: form.attr('action'),
            type: 'POST',
            data: formData,
            processData: false,
            contentType: false,
            success: function (result) {
                if (result && result.code === 200) {
                    Swal.fire('上传成功!', '', 'success').then(() => {
                        location.reload(); // 或按需更新音频列表
                    });
                }
            },
            error: function (xhr) {
                $this.removeClass('loadingbar gray').prop('disabled', false);
                const errors = xhr.responseJSON?.errors || { general: '保存失败,请重试' };
                Swal.fire('操作失败', Object.values(errors).join('<br>'), 'error');
            }
        });
    });
});

? 额外建议与最佳实践:

  • 避免全局选择器污染:若 #saveaudios 仅存在于模态框内,可改用更精确的委托目标(如 $('#audioListings').on(...)),减少事件冒泡开销。
  • 统一数据获取方式:使用 $(element).data('key') 替代 getAttribute(),兼容 HTML5 data-* 属性解析与驼峰转换(如 data-text-id → .data('textId'))。
  • 服务端兜底防护:即使前端修复,也应在后端对关键操作(如文件上传)添加幂等性校验(如 token 校验、时间窗口限制),实现双重保障。
  • 现代替代方案:长期项目建议逐步迁移至原生 addEventListener + AbortController,或使用 Axios + React/Vue 组件化管理事件生命周期,从根本上规避 jQuery 事件堆积风险。

通过 off().on() 的显式控制,配合按钮禁用与结构化错误处理,即可彻底杜绝“单击多发”问题,提升用户体验与系统稳定性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

329

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

285

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

540

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

378

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

127

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

78

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

69

2025.08.05

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

528

2023.10.23

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

4

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
jQuery 教程
jQuery 教程

共42课时 | 6万人学习

HTML+CSS基础与实战
HTML+CSS基础与实战

共132课时 | 10.9万人学习

tp6+adminlte搭建通用后台
tp6+adminlte搭建通用后台

共39课时 | 5.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号