4

根据我之前阅读的 Scott Guthrie 的一篇文章Mads Kristensen 发布的视频,我应该能够通过替换以下内容在 ASP.net MVC 4 中自动捆绑/缩小:

<link href="Styles/reset.css" rel="stylesheet" type="text/css" />
<link href="Styles/normalize.css" rel="stylesheet" type="text/css" />
<link href="Styles/styles.css" rel="stylesheet" type="text/css" />

<script src="Scripts/jquery-1.8.0.min.js" type="text/javascript"></script>
<script src="Scripts/jquery-validation.min.js" type="text/javascript"></script>

有了这个:

<link href="Styles/css" rel="stylesheet" type="text/css" />

<script src="Scripts/js" type="text/javascript"></script>

我尝试同时针对 .Net 4.0 和 4.5,但似乎没有什么不同。我收到 404 错误,并且链接和脚本标签永远不会指向捆绑的资源。

此功能是否已从最终版本中删除?

我想将此功能用于“主题”。


这就是我最终实施的方式。希望这是有道理的...

 /// <summary>
 /// Render stylesheets HTML for the given theme. Utilizes System.Web.Optimization for bundling and minification
 /// </summary>
 /// <param name="themeName">Name of theme</param>
 /// <returns>HtmlString containing link elements</returns>
 public static IHtmlString RenderThemeStyles(string themeName)
 {
     IHtmlString retValue = null;

     // If no theme name is passed, return null
     if (!themeName.HasValue())
         return retValue;

     var ctxt = HttpContext.Current;
     string themePath = "~/Themes/" + themeName;
     string themeKey = themePath + "/css";

     if (ctxt.Cache[themeKey] != null)
         return (IHtmlString)ctxt.Cache[themeKey];

     // Check to see if the theme directory exists. Throw error if it does not
     string themeSysPath = HttpContext.Current.Server.MapPath(themePath);
     DirectoryInfo themeDir = new DirectoryInfo(themeSysPath);
     if (!themeDir.Exists)
         throw new ApplicationException(string.Format("Theme directory \"{0}\" does not exist", themePath));

     // Remove the old bundle if it already exists
     var old_bundle = BundleTable.Bundles.FirstOrDefault(b => b.Path == themeKey);
     if (old_bundle != null)
         BundleTable.Bundles.Remove(old_bundle);

     if (themeDir.GetFiles("*.css").Length > 0)
     {
         // If there are css files, add them to the bundler and save the rendered output to cache
         Bundle styles = new StyleBundle(themeKey).IncludeDirectory(themePath, "*.css");
         BundleTable.Bundles.Add(styles);
         retValue = Styles.Render(themeKey);
         ctxt.Cache.Insert(themeKey, retValue, new System.Web.Caching.CacheDependency(themeSysPath));
     }
     else
     {
         // If there are no css files, save empty string to cache
         ctxt.Cache.Insert(themeKey, new HtmlString(string.Empty), new System.Web.Caching.CacheDependency(themeSysPath));
     }

     return retValue;
 }
4

2 回答 2

6

是的,这个功能在 MVC4 RC 版本中被删除了,尽管我再也找不到 RC 发行说明了。

Rick Anderson 关于将 MVC4 beta 升级到 RC的博文描述了这个过程:

删除“自动捆绑”引用并BundleConfig.cs使用您的捆绑配置创建/复制 a 并从 Global.asax 中调用它BundleConfig.RegisterBundles(BundleTable.Bundles);

Hanselman 提到了有关该决定的一些背景信息:

自测试版以来,Web 优化(缩小和捆绑)框架发生了一些重大变化。对捆绑的内容和 beta 中的顺序没有足够的控制,所以它被移到了 BundleConfig.cs(或 .vb)中,你可以完全控制

于 2012-09-03T05:33:15.783 回答
6

不完全是,所以我们删除EnableDefaultBundles了您所说的“自动捆绑”,但底层功能仍然存在。

您可以通过注册来执行与该方法相同的操作:

BundleTable.Bundles.Add(new DynamicFolderBundle("js", "*.js");
BundleTable.Bundles.Add(new DynamicFolderBundle("css", "*.css");

我们删除了该方法,因为这是一种相当有问题的方法,因为字母顺序通常不是所需的顺序。

于 2012-09-04T09:38:51.240 回答