缓慢加载第一页 - ASP.NET MVC

时间:2012-07-17 09:01:35

标签: asp.net-mvc-3 entity-framework ninject mvc-mini-profiler

我在我的页面使用了miniprofiler,因为我认为我的第一页和其他一些页面的加载时间很长。我开始使用miniprofiler,但我认为这是非常好的工具。我有这个结果:

  • http://localhost:50783/ 192.2 +0.0
    • 从数据库获取文章2.2 +186.9
    • 查找:索引866.4 +190.9
    • 渲染:索引1839.0 +1058.1
      • 查找:_文章530.0 +2809.0
      • 渲染部分:_文章64.3 +3339.2
      • 渲染部分:_第8.2条+3404.2
      • 渲染部分:_文章12.5 +3413.0
      • 渲染部分:_文章8.7 +3426.2
      • 渲染部分:_第7.9条+3435.4
      • 渲染部分:_LeftMenu 64.8 +3520.4
      • 渲染部分:_LogOnPartial 3.3 +3556.3
      • 渲染部分:_RightMenuTest 2530.1 +3591.2
      • 渲染部分:_NextMatch 3.5 +4088.7
      • 渲染部分:_Standings 4.7 +4226.5
      • 渲染部分:_Footer 21.2 +6137.4

任何人都可以帮我减少查找的时间吗?这是什么意思?我知道RightMenuTest有最大的时间,我也试图减少它。我在那里有很多我自己的助手,我认为这是局部视图_RightMenuTest的问题。所以我需要帮助减少其他时间。

谢谢

编辑:

_Article:

@model SkMoravanSvitavka.Models.Article
<h3>@Html.ActionLink(Model.Title, "Zobrazit", "Clanek", new { id = Model.ArticleID }, null)</h3>

    <p>@Html.Raw(Html.ArticleImageToSmall(Html.Article(Model.Text))) </p>

@Html.ActionLink("Počet komentářů:" + Model.Comments.Count, "Zobrazit", "Clanek", new { id = Model.ArticleID }, null)

文章的索引视图:

@model IEnumerable<SkMoravanSvitavka.Models.Article>
@{
    ViewBag.Title = "Sk Moravan Svitávka - oficiální stránky fotbalového klubu";
}
@if (Model != null)
{
    foreach (var item in Model)
    {
        @Html.Partial("_Article", item);
    }
}

文章控制器中的索引:

public ActionResult Index()
        {
            var profiler = MiniProfiler.Current;
            using (profiler.Step("Getting articles from database"))
            {
                var model = repo.GetLatestArticles(5);
                return View(model);
            }
        }

2 个答案:

答案 0 :(得分:0)

尝试使用RenderPartial而不是Partial:

foreach (var item in Model)
{
    Html.RenderPartial("_Article", item);
}

答案 1 :(得分:0)

确保在发布模式下编译项目时也要进行测试。众所周知,ASP MVC执行额外的反射以在调试模式下查找视图,以获得更全面的调试功能。