最近,我的项目本地副本完全失去了大部分样式。花了一些时间才弄明白,因为大多数样式都是在一个文件中完成的,其余的都是像Kendo和jQuery UI这样的小东西。
其他的小东西没有被添加到页面中。我认为这些样式已经被其他开发人员修改过了(暂时还没有触及过这个项目),他们只测试了Web API的东西而不是UI,所以他可能会破坏它并且从来不知道,但我追查了这个问题:只有site.css
文件包含在捆绑包中,而没有其他文件。我甚至尝试重新排列捆绑包中包含的CSS文件的顺序,它只包括site.css
。
我重建了项目,清理了缓存等,所以肯定会看到变化。我记得最近更新了一些NuGet包或VS包或者其他东西 - 甚至可能是MVC包?
我的问题是:是否有任何改变导致这种情况发生?造成这种情况的原因是什么?
编辑:来自BundleConfig.cs
的代码:
public static void RegisterBundles(BundleCollection bundles)
{
bundles.Add(new StyleBundle("~/Content/css").Include(
"~/Content/site.css",
"~/Content/themes/kendo/kendo.common.min.css",
"~/Content/themes/kendo/kendo.default.min.css",
"~/Content/themes/base/minified/jquery.ui.core.min.css",
"~/Content/themes/base/minified/jquery.ui.resizable.min.css",
"~/Content/themes/base/minified/jquery.ui.selectable.min.css",
"~/Content/themes/base/minified/jquery.ui.accordion.min.css",
"~/Content/themes/base/minified/jquery.ui.autocomplete.min.css",
"~/Content/themes/base/minified/jquery.ui.button.min.css",
"~/Content/themes/base/minified/jquery.ui.dialog.min.css",
"~/Content/themes/base/minified/jquery.ui.slider.min.css",
"~/Content/themes/base/minified/jquery.ui.tabs.min.css",
"~/Content/themes/base/minified/jquery.ui.datepicker.min.css",
"~/Content/themes/base/minified/jquery.ui.progressbar.min.css",
"~/Content/themes/base/minified/jquery.ui.theme.min.css"));
}
来自_Layout.cshtml
的代码:
@Styles.Render("~/Content/themes/base/css", "~/Content/css")
答案 0 :(得分:55)
默认情况下,名称以“ .min.css ”结尾的文件只会包含在发布版本中。
推荐的捆绑包配置仅包含非缩小的.css和.js文件,然后将在发布版本中自动选择.min版本(如果存在),即中的<compilation debug="false">
的web.config 强>
您可以通过清除然后向BundleCollection.IgnoreList
添加忽略规则来控制此行为。示例BundleConfig
可能如下所示:
public static class BundleConfig
{
public static void RegisterBundles(BundleCollection bundles)
{
ConfigureIgnoreList(bundles.IgnoreList);
// Setup your bundles...
}
public static void ConfigureIgnoreList(IgnoreList ignoreList)
{
if (ignoreList == null) throw new ArgumentNullException("ignoreList");
ignoreList.Clear(); // Clear the list, then add the new patterns.
ignoreList.Ignore("*.intellisense.js");
ignoreList.Ignore("*-vsdoc.js");
ignoreList.Ignore("*.debug.js", OptimizationMode.WhenEnabled);
// ignoreList.Ignore("*.min.js", OptimizationMode.WhenDisabled);
ignoreList.Ignore("*.min.css", OptimizationMode.WhenDisabled);
}
}
您还可以通过设置BundleTable.EnableOptimizations
来明确启用/禁用优化。