gpt4 book ai didi

css - 从 MVC5 或 Web API 2 Controller 操作返回生成的 CSS

转载 作者:行者123 更新时间:2023-12-01 16:19:01 25 4
gpt4 key购买 nike

在我们的 Multi-Tenancy 应用程序中,我们需要自定义每个租户使用的样式。

我们目前计划在客户端通过以下方式使用 LESS 和变量:

  1. 从服务器下载依赖的 LESS 文件
  2. 调用网络服务获取配置对象
  3. 用定义的变量形成有效的 LESS 字符串
  4. 使用 less.js 编译器根据这些变量和步骤 1 中固定的 LESS 文件编译 LESS

这种方法有很多缺点:

  • 客户可能行为不端
  • 一些浏览器在 less.js 上有问题
  • 编译需要时间

我们更愿意在服务器上处理这项工作,所以粗略地说,这发生在服务器上:

  1. 客户端请求下载一个大的编译样式表 - GET content/styles/{tenantName}.css
  2. 服务器使用 tenantName 获取配置
  3. 使用模板和适当的变量(可能是 string.Format 或更复杂的东西)
  4. 服务器将 LESS 编译成 CSS 字符串
  5. 服务器返回带有适当Content-Type的CSS字符串

这是我的问题:

  1. 这是实现上述结果的不寻常或不受欢迎的方式吗?
  2. 没有为服务器端 JavaScript 设置架构,如何将 LESS 编译成 CSS?
  3. 我必须在 Controller 操作或路由配置中做些什么才能让客户端认为服务器正在返回一个常规的旧 CSS 文件,完成缓存控制,没有修改?

最佳答案

你可以使用 BundleTransformer编译你的 LESS 服务器端。

这取决于您希望如何提供文件。如果您知道所有租户,则只需将每个租户应用程序的捆绑 url 添加到捆绑配置中。

 var themeStyles = new CustomStyleBundle("~bundles/theme/tenant").Include("~/Content/theme.less");
themeStyles.Builder = new ThemeBuilder();
BundleTable.Bundles.Add(themeStyles);

如果您不这样做,并且租户像我们的情况一样灵活,那么请为您的主题添加以下 Controller 操作。

    [Route("bundles/theme/{id}")]
public ContentResult Theme(string id)
{
var tenantThemePath = string.Format("~/bundles/theme/{0}", id);

// Check that bundle has not already been added.
if (BundleTable.Bundles.All(x => x.Path != tenantThemePath))
{
var themeStyles = new CustomStyleBundle(tenantThemePath ).Include("~/Content/theme.less");

themeStyles.Builder = new ThemeBuilder();

BundleTable.Bundles.Add(themeStyles);
}

var context = new BundleContext(HttpContext, BundleTable.Bundles, institutionPath);

var response = BundleTable.Bundles.GetBundleFor(tenantThemePath).GenerateBundleResponse(context);

Response.Cache.SetCacheability(response.Cacheability);

return Content(response.Content, response.ContentType);
}

BundleTransformer 的 ThemeBuilder 实现

public class ThemeBuilder : IBundleBuilder
{
public string BuildBundleContent(Bundle bundle, BundleContext context, IEnumerable<BundleFile> files)
{
var lessTranslator = bundle.Transforms.OfType<StyleTransformer>()
.Where(x => x != null)
.Select(x => x.Translators.OfType<LessTranslator>().FirstOrDefault())
.FirstOrDefault();

if (lessTranslator == null)
{
return string.Empty;
}

lessTranslator.GlobalVariables = GetThemeVariables();

return string.Empty;
}

private string GetThemeVariables()
{
// Simplified for brevity
// This will be translated to less variables by the BundleTransformer
// themeColour should correspond to a variable name in your less file.
return string.Format("themeColour={0}", themeColour);
}

}

您需要远离获取主题颜色,我们将这些变量存储在 HttpContext 存储中,以便我们可以使用 GetThemeVariables 方法中的扩展方法将它们提取出来。

希望对您有所帮助。

更新我扩展了我的原始答案并创建了一种包含主题的更可重用的方式。

演示站点在这里:http://bundletransformer-theme-builder.azurewebsites.net/

此处为 GitHub 存储库:https://github.com/benembery/bundle-transformer-theme-builder

关于css - 从 MVC5 或 Web API 2 Controller 操作返回生成的 CSS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25053327/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com