在ASP.NET MVC中动态地从数据库生成CSS文件
发布时间:2021-01-12 12:30:17 所属栏目:asp.Net 来源:互联网
导读:我正在寻找一些基本的主题支持我的Web应用程序,用户可以自定义外观的各个部分.这些包括颜色,文字大小,字体,其他基本的东西.我将把它们存储在数据库中,并在每次访问页面时加载它们. 我的问题是,如何根据这些数据库值生成动态CSS文件? 我宁愿做一些可缓存的东
|
我正在寻找一些基本的主题支持我的Web应用程序,用户可以自定义外观的各个部分.这些包括颜色,文字大小,字体,其他基本的东西.我将把它们存储在数据库中,并在每次访问页面时加载它们. 我的问题是,如何根据这些数据库值生成动态CSS文件? 我宁愿做一些可缓存的东西,但是可扩展,所以如果我想添加更多可编辑的样式,那么这不是一个问题. 解决方法我认为最简单的方法是将如下操作方法添加到控制器中:public class CssController : Controller {
public ActionResult GetCss() {
StringBuilder sb = new StringBuilder();
Dictionary<string,string> cssValues = new Dictionary<string,string>();
// populate dictionary with values from your database
sb.AppendLine(".myDivClass {");
foreach (var entry in cssValues) {
sb.AppendLine(entry.Key + ": " + entry.Value);
}
sb.AppendLine("}");
return Content(sb.ToString(),"text/css");
}
}
现在在您的页面中,您可以这样引用: <link href="<%: Url.RouteUrl(new { controller= "CssController",action = "GetCss" }) %>" rel="stylesheet" type="text/css" />
OP编辑:我对该方法进行了一些小的改动,但总的前提依然存在.这是我使用的版本: public class CssController : Controller
{
public ContentResult GetTheme()
{
var builder = new StringBuilder();
IDictionary<string,IDictionary<string,string>> css = new Dictionary<string,string>>();
/* Populate css object from the database */
foreach (var selector in css)
{
builder.Append(selector.Key);
builder.Append(" { ");
foreach (var entry in selector.Value)
{
builder.Append(string.Format("{0}: {1}; ",entry.Key,entry.Value));
}
builder.AppendLine("}");
}
return Content(builder.ToString(),"text/css");
}
} (编辑:东莞站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net – 部分视图呈现按钮点击
- 如何在ASP.NET自定义控件中持久保存List属性?
- ASP.NET MVC学习教程之Razor语法
- asp.net-mvc – 路由是在我的区域中找到控制器,但不是视图
- asp.net-mvc – ASP.NET MVC:部分知道它是否是从另一个页面
- asp.net-mvc – ASP.NET MVC WebSite中的ERR_EMPTY_RESPONS
- ASP.NET MVC下Ajax.BeginForm方式无刷新提交表单实例
- asp.net-mvc – 从基本控制器继承LINQ-to-SQL数据上下文
- asp.net-mvc – 如何组合两个dataTextFields的SelectList描
- asp.net-mvc – ASP.NET MVC Beta 1:DefaultModelBinder错
推荐文章
站长推荐
热点阅读
