8

在提供呈现捆绑脚本的简单页面时,我的 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这么慢?

4

1 回答 1

4

问题出在我安装的过时软件包上。一个简单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()表现好多了:-)

于 2012-11-07T17:50:09.017 回答