gpt4 book ai didi

jquery - 加载动画只有在 ajax 调用完成后才会显示

转载 作者:行者123 更新时间:2023-12-03 22:44:31 24 4
gpt4 key购买 nike

可能的重复:Same problem (unresolved)

我在 Ajax 调用之前显示加载 DOM,在 Ajax 调用之后隐藏它。由于某种原因,加载图像仅在 ajax 调用完成后才出现。结果是加载图像甚至不会出现,除非我输入 delay(#).hide(0) 代码如下:

$("#loading-popup").show();
$.ajax({
// ajax here
});
$("#loading-popup").hide(0);

我在我的网站上的其他 Ajax 调用上进行了测试,也出现了同样的问题。有人解决这个问题了吗?我使用的是 Chrome 26。

编辑:我忘记指定我正在使用同步 ajax 调用。 (异步:false)

最佳答案

这取决于ajax调用是同步还是异步。

对于异步 ajax 调用,可以执行以下操作:

$("#loading-popup").show();
$.ajax({
type: 'POST',
// other parameters
success: function(yourdata)
{
$("#loading-popup").hide();
}

对于同步 ajax 调用,它。 Ajax 首先执行,所有其他进程都被阻止/排队。

解决这个问题的方法是像这样使用 setTimeOut:

setTimeout(function () {
$("#loading-popup").show();
$.ajax({
type: 'POST',
async: false,
// other parameters
//
// other codes
});
$("#loading-popup").hide();
}, 10);

但是因为它是同步的,加载的 GIF 不会动画而只是变成静态图像(至少对于 Chrome 来说是这样)

我想只有两种解决方案:
1)使用异步ajax调用
2)使用静态加载图片

关于jquery - 加载动画只有在 ajax 调用完成后才会显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16000803/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com