使用Scripts.Render时MVC4捆绑速度很慢

Nic*_*ick 8 asp.net-mvc bundle asp.net-mvc-4 bundling-and-minification

当提供一个呈现捆绑脚本的简单页面时,我的asp.net MVC4 Web项目运行速度非常慢.但是,当我在页面上使用带有虚拟包路径的source属性的"硬编码"脚本标记时,性能要好得多:

@Scripts.Render("~/bundles/scripts")                            ~ 4 seconds
Run Code Online (Sandbox Code Playgroud)

VS

<script src='@Scripts.Url("~/bundles/scripts")'></script>       < 1 second
Run Code Online (Sandbox Code Playgroud)

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"));
Run Code Online (Sandbox Code Playgroud)

web.config甚至配置为在Debug中进行优化,但我尝试在Release模式下运行并仍然得到相同的结果:

<compilation optimizeCompilations="true" debug="false" targetFramework="4.0" />
Run Code Online (Sandbox Code Playgroud)

任何想法为什么Scripts.Render这么慢?

Nic*_*ick 4

问题出在我安装的过时的软件包上。一个简单的Update-Package包管理器控制台,我从

<package id="Microsoft.AspNet.Web.Optimization"
    version="1.0.0-beta2" targetFramework="net40" />
Run Code Online (Sandbox Code Playgroud)

<package id="Microsoft.AspNet.Web.Optimization"
    version="1.0.0" targetFramework="net40" />
Run Code Online (Sandbox Code Playgroud)

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

  • 在 1.1.0 上,看到脚本包(10 个 .js 文件)的加载时间非常长...始终需要 7-9 秒...还有其他人吗? (5认同)
  • 我有一个新包,但速度仍然很慢。有什么建议吗?&lt;package id="Microsoft.AspNet.Web.Optimization" version="1.1.3" targetFramework="net45" /&gt; (5认同)
  • 我也有这个问题。您找到解决方案了吗? (3认同)
  • 我对 Microsoft.AspNet.Web.Optimization 包的版本 1.1.3 有完全相同的问题 (3认同)