【发布时间】:2012-06-26 18:25:37
【问题描述】:
我正在 MVC4 中实现捆绑和缩小支持并对其进行设置,以便它可以自动为我编译我的 Bootstrap .less 文件。我的 BundleConfig.cs 文件中有以下代码
public class BundleConfig
{
public static void RegisterBundles(BundleCollection bundles)
{
// base bundles that come with MVC 4
var bootstrapBundle = new Bundle("~/bundles/bootstrap").Include("~/Content/less/bootstrap.less");
bootstrapBundle.Transforms.Add(new TwitterBootstrapLessTransform());
bootstrapBundle.Transforms.Add(new CssMinify());
bundles.Add(bootstrapBundle);
}
}
TwitterBootsrapLessTransform 如下(它比我想的要复杂,因为需要将 sub .less 文件导入 dotLess)
public class TwitterBootstrapLessTransform : IBundleTransform
{
public static string BundlePath { get; private set; }
public void Process(BundleContext context, BundleResponse response)
{
setBasePath(context);
var config = new DotlessConfiguration(DotlessConfiguration.GetDefault());
config.LessSource = typeof(TwitterBootstrapLessMinifyBundleFileReader);
response.Content = Less.Parse(response.Content, config);
response.ContentType = "text/css";
}
private void setBasePath(BundleContext context)
{
BundlePath = context.HttpContext.Server.MapPath("~/Content/less" + "/imports" + "/");
}
}
public class TwitterBootstrapLessMinifyBundleFileReader : IFileReader
{
public IPathResolver PathResolver { get; set; }
private string basePath;
public TwitterBootstrapLessMinifyBundleFileReader(): this(new RelativePathResolver())
{
}
public TwitterBootstrapLessMinifyBundleFileReader(IPathResolver pathResolver)
{
PathResolver = pathResolver;
basePath = TwitterBootstrapLessTransform.BundlePath;
}
public bool DoesFileExist(string fileName)
{
fileName = PathResolver.GetFullPath(basePath + fileName);
return File.Exists(fileName);
}
public byte[] GetBinaryFileContents(string fileName)
{
throw new System.NotImplementedException();
}
public string GetFileContents(string fileName)
{
fileName = PathResolver.GetFullPath(basePath + fileName);
return File.ReadAllText(fileName);
}
}
在我的基本 _Layout.cshtml 页面上,我尝试通过这样做来呈现 css 文件
@Styles.Render("~/bundles/bootstrap");
正如mvc tutorial 所建议的,但客户端浏览器最终请求的文件是
http://localhost:53729/Content/less/bootstrap.less
这会导致错误。如果我将以下链接按基本布局页面放入,它将按预期工作。
<link href="~/bundles/bootstrap" rel="stylesheet" type="text/css" />
为什么@Styles.Render() 在调试模式下的行为方式不同?它在发布模式下工作。我可以理解您不希望它在调试中捆绑和缩小,但我如何才能强制此捆绑始终以相同的方式工作?
【问题讨论】:
-
我发现这段代码 sn-p 非常有用。你应该考虑写一篇关于你如何让 Twitter Bootstrap 和 Dotless 协同工作的博客文章。
-
谢谢,也许等我有更多的时间我会开始写博客。
-
@PITaylor 您是否感兴趣地在 css 输出中看到以下类型的错误: 缩小失败。返回未缩小的内容。 (1381,2): 运行时错误 CSS1019: Unexpected token, found '{'...
-
我的 kendo min css 文件有问题。油脂猴缩小器似乎有点敏感。
标签: asp.net-mvc-4 bundling-and-minification asp.net-optimization