gpt4 book ai didi

c# - 为什么这个 AJAX 调用需要这么长时间?

转载 作者:行者123 更新时间:2023-11-29 16:19:34 24 4
gpt4 key购买 nike

这通常需要 2-4 秒,这对于它正在做的工作来说似乎太长了。这是 AJAX:

$("#IngTable").html("<center><img src=../img/loading.gif /></center>");

var search = document.getElementById("IngSearch").value;
var apiLink = "/API/Ingredient/Search?search=" + search;
$.ajaxSetup({ accepts: "application/json" });
$.ajax({
url: apiLink,
type: "GET",
success: function(data) {
var ingredients = JSON.parse(data);
var htmlIngred = "";
for (var i = 0; i < ingredients.length; i++) {
htmlIngred += "<tbody><td><span>" + ingredients[i].Name + "</span></td><td><a class='btn btn-success btn-mini' onclick='addIngred(" + ingredients[i].IngredientId + ");'>Add</a></td></tbody>";
}
document.getElementById("IngTable").innerHTML = htmlIngred;
},
error: function (a, b, c) { }
});

这是 Web API Controller :

    [HttpGet]
public string IngredientSearch(string search)
{
var sw = Stopwatch.StartNew();
var db = new Glubee.Model.GlubeeEntities();
var results = db.Ingredients.Where(x => x.Name.Contains(search)).ToArray();
sw.Stop();
return JsonConvert.SerializeObject(results);
}

配料表只有16种东西,每一种都不超过20个字符。

有没有人知道问题出在哪里导致它花了这么长时间?

编辑:如果有帮助,这是我的 Global.asax.cs 页面:

public class MvcApplication : System.Web.HttpApplication
{
protected void Application_Start()
{
AreaRegistration.RegisterAllAreas();

FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
RouteConfig.RegisterRoutes(RouteTable.Routes);
BundleConfig.RegisterBundles(BundleTable.Bundles);
}

这是我的 RouteConfig:

public class RouteConfig
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional }
);

routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
}
}

最佳答案

您是否确定了到底是什么地方慢了?

例如;在您的 IngredientSearch 方法中,如果您将代码更改为

[HttpGet]
public string IngredientSearch(string search)
{
var sw = Stopwatch.StartNew();
var db = new Glubee.Model.GlubeeEntities();
var results = db.Ingredients.Where(x => x.Name.Contains(search)).ToArray();
sw.Stop();
return JsonConvert.SerializeObject(results);
}

[HttpGet]
public string IngredientSearch(string search)
{
return String.Empty;
}

还需要很长时间吗?

如果是这样;然后我们必须看一个脚本库问题;如果不是 - 那么就是您的数据库层出了问题。

像这样的错误通常很难追踪,因此您必须忘记假设并一点一点地进行测试。上述更改消除了很多问题,只需很少的努力就可以为您提供很大的线索。

PS:抱歉,我知道这不是一个答案;但我想把它作为一个发布,这样我就可以清楚地突出代码更改;请不要投反对票!

关于c# - 为什么这个 AJAX 调用需要这么长时间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11927123/

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