使用ClientDependency Framework动态添加CSS或JS的正确方法是什么?
本文关键字:方法 是什么 JS Framework ClientDependency 动态 添加 CSS 使用 | 更新日期: 2023-09-27 18:14:37
很抱歉,这里缺少文档:https://github.com/Shazwazza/ClientDependency/wiki/Webforms
我正在尝试动态注册依赖项,无法获得语法正确:
<%@ Page Language="C#" AutoEventWireup="false" %>
<%@ Register TagPrefix="CD" Namespace="ClientDependency.Core.Controls" Assembly="ClientDependency.Core" %>
<script runat="server">
protected override void OnLoad(EventArgs e)
{
if (Request.Cookies["AAPGmobile"] != null && Request.Cookies["AAPGmobile"].Value == "Mobile")
{
//mobile
ClientDependencyLoader.RegisterDependency("~/Style/mobile.css",ClientDependencyType.Css);
}
else
{
//desktop
ClientDependencyLoader.RegisterDependency("~/Style/desktop.css",ClientDependencyType.Css);
}
}
</script>
文档头:
<CD:ClientDependencyLoader runat="server" id="Loader" />
<asp:PlaceHolder runat="server" ID="CssPlaceHolder"></asp:PlaceHolder>
<asp:PlaceHolder runat="server" ID="JavaScriptPlaceHolder"></asp:PlaceHolder>
我也试过使用这个,但得到一个错误:
bool successfullyCreated;
var loader = ClientDependencyLoader.TryCreate(this.Page, out successfullyCreated);
和这个,但是得到了一个不同的错误:
var loader = ClientDependencyLoader.GetInstance(currentHttpContext);
请帮助语法或指给我正确的方向。谢谢!
这是我发现的似乎有效的解决方案-我在这里发布,以防其他人遇到类似的情况:
CSS:ClientDependencyLoader.Instance.RegisterDependency("~/Style/mobile.css",ClientDependency.Core.ClientDependencyType.Css);
JS: ClientDependencyLoader.Instance.RegisterDependency("~/Style/mobile.js",ClientDependency.Core.ClientDependencyType.Javascript);
请注意,我并没有试图单独创建或引用一个现有的Loader,语法会照顾它。
解决方案改编自本页的代码:https://our.umbraco.org/forum/developers/razor/35307-Using-ClientDependency-Framework-from-a-Razor-Macro
希望这能帮助到一些人!