在ajax调用中设置延迟

Set a delay in ajax call

本文关键字:设置 延迟 调用 ajax      更新时间:2023-09-26

我试图在加载程序图标和成功之间添加一个小延迟(2秒),数据为html。

我尝试使用的是setTimeout,并输入一个延迟数。这不起作用,所以我希望你能告诉我什么是正确的方法

我的ajax代码:

<script type="text/javascript">
$(function () {
    var delay = 2000;
    var res = {
        loader: $("<div />", { class: "loader" })
    };
    $('#search').on('click', function () {
        $.ajax({
            type: 'GET',
            url: "@Url.Action("Find", "Hotel")",
            datatype: "html",
            beforeSend: function () {
                $("#group-panel-ajax").append(res.loader);
                setTimeout(delay);
            },
            success: function (data) {
                $("#group-panel-ajax").find(res.loader).remove();
                $('#group-panel-ajax').html($(data).find("#group-panel-ajax"));
            }
        });
        return false;
    });
});
</script>

现在它跑得很快。希望有人能帮忙。

setTimeout应在success function内部使用。

$(function() {
  var delay = 2000;
  var res = {
    loader: $("<div />", {
      class: "loader"
    })
  };
  $('#search').on('click', function() {
    $.ajax({
      type: 'GET',
      url: "@Url.Action("Find", "Hotel")",
      datatype: "html",
      beforeSend: function() {
        $("#group-panel-ajax").append(res.loader);
      },
      success: function(data) {
        setTimeout(function() {
          delaySuccess(data);
        }, delay);
      }
    });
    return false;
  });
});
function delaySuccess(data) {
  $("#group-panel-ajax").find(res.loader).remove();
  $('#group-panel-ajax').html($(data).find("#group-panel-ajax"));
}
<script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

当我想做同样的事情时,我发现了一些东西:

function doStuff()
{
  //do some things
  setTimeout(continueExecution, 10000) //wait ten seconds before continuing
}
function continueExecution()
{
   //finish doing things after the pause
}

希望它能帮助你的

像这样使用setTimeout()

<script type="text/javascript">
$(function () {
    var delay = 2000;
    var res = {
        loader: $("<div />", { class: "loader" })
    };
    $('#search').on('click', function () {
        $.ajax({
            type: 'GET',
            url: "@Url.Action("Find", "Hotel")",
            datatype: "html",
            beforeSend: function () {
                $("#group-panel-ajax").append(res.loader);
            },
            success: function (data) {
                setTimeout(function(){
                     $("#group-panel-ajax").find(res.loader).remove();
                     $('#group-panel-ajax').html($(data).find("#group-panel-ajax"));
                }, delay);
            }
        });
        return false;
    });
});
</script>