Asp.net-Mvc

使用 Scripts.Render 時 MVC4 捆綁速度慢

  • November 7, 2012

在提供呈現捆綁腳本的簡單頁面時,我的 asp.net MVC4 Web 項目執行非常緩慢。但是,當我在頁面上使用帶有虛擬包路徑的源屬性的“硬編碼”腳本標記時,性能會好得多:

@Scripts.Render("~/bundles/scripts")                            ~ 4 seconds

對比

<script src='@Scripts.Url("~/bundles/scripts")'></script>       < 1 second

BundleConfig.cs的沒有特殊配置,這與它看起來完全一樣:

bundles.Add(new ScriptBundle("~/bundles/scripts").Include(
   "~/Scripts/jquery-1.7.2.min.js",
   "~/Scripts/jquery.validate.min.js",
   "~/Scripts/jquery.validate.unobtrusive.js",
   "~/Scripts/jquery-ui-1.9.0.custom.min.js",
   "~/Scripts/bootstrap.min.js",
   "~/Scripts/bootstrap-modal.js",
   "~/Scripts/bootstrap-dropdown.js",
   "~/Scripts/bootstrap-tooltip.js",
   "~/Scripts/bootstrap-typeahead.js",
   "~/Scripts/bootstrap-transition.js",
   "~/Scripts/bootstrap-popover.js"));

web.config什至被配置為在調試中進行優化,但我嘗試在發布模式下執行並且仍然得到相同的結果:

<compilation optimizeCompilations="true" debug="false" targetFramework="4.0" />

任何想法為什麼Scripts.Render這麼慢?

問題出在我安裝的過時軟體包上。一個簡單Update-Package的包管理器控制台,我從

<package id="Microsoft.AspNet.Web.Optimization"
   version="1.0.0-beta2" targetFramework="net40" />

<package id="Microsoft.AspNet.Web.Optimization"
   version="1.0.0" targetFramework="net40" />

現在Scripts.Render()表現好多了:-)

引用自:https://stackoverflow.com/questions/13267189