问题 为什么我的jquery ajax请求执行多次?


当我点击执行ajax请求的函数时,我正在查看firebug中的控制台。问题是,只需单击一个按钮就可以发送1个ajax请求,但我发送了2个请求!

我的js的代码如下所示:

$(document).ready(function() {
   $('.book_now').click(function(){


$.ajax({
  type: 'POST',
  url: '/booking.php',
  data: 'event_id='+event_id+'&time_id='+time_id,
  success: function(data) {
    console.log('inside');
    $('#booking_box_content').html(data);
  }
});


  });
});

哪个看起来很直接吧?

然而,在我的控制台中,我看到1次点击后出现2次GET请求。

我的按钮很简单:

<div class="book_now"></div>

我错过了什么 - 应该有2个GET请求吗?

是否有机会在加载新文件时再次加载$(document).ready()函数并再次执行click函数?

注意:我不是双击按钮。它可能无关紧要,但如果我将其更改为POST,它也会两次。

编辑:来自booking.php的回复

<div id="booking_box_left">
  <h1 class="speaker_name"></h1>
  <h1 class="event_name"></h1>

  <div class="event_start_header">Start</div><div id="event_start_datetime">, </div>
  <div class="cleared"></div>
  <div class="event_end_header">End</div><div id="event_end_datetime">, </div>
  <div class="cleared"></div>
  <div class="event_where_header">Where</div><div id="event_where"><strong></strong><br /><br />
</div>

</div>
<div id="booking_box_right_container">
  <form id="booking_form_1" method="post">
    <input type="hidden" name="booking_id" value="7a614fd06c325499f1680b9896beedeb" />
    <input type="hidden" name="event_id" value="" />
    <input type="hidden" name="time_id" value="" />
    <div id="booking_box_right">
      <h1>To reserve your seat</h1>
      <input type="text" name="booking_email" class="enterSomething booking_email" title="Enter your email..." />
      <div class="booking_email_helper">On clicking next a ticket will be held for you for a short period for you to complete your registration.</div>
      <input type="submit" id="next" value="Next" />
    </div>
  </form>
</div>

注意:根据我的知识,此响应中没有任何功能被触发。我怀疑响应是两次触发ajax请求...如果click函数只运行一次,那么它可能不是按钮正在执行该函数两次,而是$ .ajax()部分,即成功回调即。我已经更新了JS代码,以显示我如何构建console.log()的东西。

最终编辑:

我的ajax函数包含在以下内容中:

   $('#shade, #booking_box').fadeIn(function(){

     // ajax function

  }

我不知道,但是当#shade(我的thickbox)和#booking_box进来因此运行它时,它正在调用此函数! :(

我觉得这样的工具。

谢谢大家的帮助。


4901
2017-08-27 03:02


起源

也许某些东西在你的其他代码中是不对的,但是这应该工作得很好并且只是一个请求。 演示 - Reigel
你有机会 .book_now 嵌套在另一个? - user113716
关闭主题:我确定这里的名字只是有点误导,但你知道一个 得到 请求永远不会更改服务器上的数据吗? “book_now”听起来像是一个会引起变化的动作,因此应该是一个POST。 - tster
这应该工作。问题100%是未发布的代码。 - Mark
@TML:因为它没有回答任何问题,除非提问者是平坦的 说谎。希望KeenLearner最终能够提供一些信息,帮助我们确定问题的原因;在那之前,没有答案。 - Shog9♦


答案:


可能会发生一些事情:

  1. 点击处理程序已绑定两次。更改 $('.book_now').click(function(){ 至 $('.book_now').unbind('click').click(function(){ 调试。稍后您可以重构您的代码以供使用 $('.book_now').unbind('click',handler).click(handler);

  2. 服务器端发生重定向,导致出现两个ajax请求。这意味着 console.log('inside') 只运行一次。

  3. 点击处理程序被触发两次。要对此进行调试,请通过firebug或webkit的开发人员工具向点击处理程序添加断点并手动调试。您将能够遍历“调用堆栈”并发现是否是这种情况。


8
2017-08-27 05:56





我用以下JS将我的函数放在2个div中

$('#shade, #booking_box').fadeIn(function(){

 // ajax function

}

我没有意识到,通过这样做,它将在函数内执行2次,每个div我正在消失...

解决方案是:

$('#shade').fadeIn(function(){

     $('#booking_box').fadeIn(function() {

        // ajax function

     });

});

3
2017-09-01 04:42





请删除 document.ready 从你的代码。使用简单的功能:

$('.book_now').click(function(){
  $.ajax({
    type: 'POST',
    url: '/booking.php',
    data: 'event_id='+event_id+'&time_id='+time_id,
    success: function(data) {
      console.log('inside');
      $('#booking_box_content').html(data);
    }
  });
});

3
2017-08-08 05:19



为什么要投票?您无法直接绑定未加载的元素上的事件。所以document.ready应该是必要的。 - FLX


也许有人可以从我的经验中受益。

这是我得到的地方:

脚本
    function someFunction(){
      $( “#项目”)。改变(函数(){
        //使用Ajax请求的功能
      }
    }
选择
平变化= “someFunction()”

并且给我带来了很多要求。 要解决它,我删除了 $("#item").change(function(){} 只留下代码内部


0
2017-10-08 21:22





将您的类属性更改为id,它将不再执行此操作。这是怎么解决的。


0
2017-10-15 19:00