将favicon动态加载到共享的_Layout.cshtml中

时间:2017-02-21 17:40:42

标签: c# asp.net-mvc razor

如何动态添加favicon(基于条件编程)到共享_Layout.cshtml的Razor中?主布局。

2 个答案:

答案 0 :(得分:2)

没有更多细节,基本上是:

<head>
@if (true)
{
    <link rel="shortcut icon" href="http://example.com/favicon.ico" />
}
else
{
    <link rel="shortcut icon" href="http://example.com/favicon2.ico" />
}
</head>

您可以在_Layout中执行子操作

@Html.Action("Favicon", "MyController", new { parameter = "value" })

采取行动

[ChildActionOnly]
public ActionResult Favicon(string parameter)
{
    string url = GetFaviconUrl(parameter);
    ViewBag.FaviconUrl = url;
    return PartialView();
}

和部分

<link rel="shortcut icon" href="@ViewBag.FaviconUrl" />

答案 1 :(得分:0)

我知道这个问题很旧,但是我只是必须这样做,却没有找到适合我所需的在线好方法,因此我发布此答案以给其他人可能有用的方法。

我有一个健康状态页面,并希望能够看到红色,黄色或绿色图标作为图标,以便在我研究另一个问题时,我可以快速检查公司应用程序的状态。状态页面上的每个部分都是一个ViewComponent,所有这些都可以从Index.cshtml

中调用

通过尝试各种方法,我发现_Layout.cshtml在所有View组件被渲染之后被称为,这大大简化了此过程。所有View组件均设置其特定状态,例如ApiStatusViewComponent设置Shared.ApiStatus变量。每次调用时,overallStatus都会更新(我知道这是浪费的处理器周期,但它可以工作)。到Index.cshtml调用_Layout.cshtml时,overallStatus已经反映了正确的值。

下面的代码示例:

_Layout.cshtml

<link rel="icon" type="image/png" sizes="923x923" href=@Shared.GetFavIcon() />

我知道这是一个大图标,但浏览器将其缩小到平台所需的大小。

Shared.cs

public static class Shared
    {
        private static OverallStatusEnum overallStatus;

        public static string GetFavIcon()
        {
            switch (overallStatus)
            {
                case OverallStatusEnum.Ok:
                    return "https://PathToServer/Green.png";
                case OverallStatusEnum.Warning:
                    return "https://PathToServer/Yellow.png";
                case OverallStatusEnum.Error:
                    return "https://PathToServer/Red.png";
                default:
                    return "https://PathToServer/Yellow.png";
            }
        }

        public static class Status
        {
            private static OverallStatusEnum apiStatus;
            private static OverallStatusEnum criticalServicesStatus;

            // When adding a new section to monitor, add the overall status here so the favicon can be updated
            public static OverallStatusEnum ApiStatus { get => apiStatus; set => UpdateStatus(value, nameof(ApiStatus)); }
            public static OverallStatusEnum CriticalServicesStatus { get => criticalServicesStatus; set => UpdateStatus(value, nameof(CriticalServicesStatus)); }

            private static void UpdateStatus(OverallStatusEnum status, string propertyName)
            {
                switch(propertyName)
                {
                    case nameof(ApiStatus):
                        apiStatus = status;
                        break;
                    case nameof(CriticalServicesStatus):
                        criticalServicesStatus = status;
                        break;
                }

                overallStatus = (OverallStatusEnum)GetHighestStatusLevel();
            }

            private static int GetHighestStatusLevel()
            {
                var highestLevel = -1;
                var type = typeof(Status);
                foreach (var p in type.GetFields(BindingFlags.Static | BindingFlags.NonPublic))
                {
                    var v = p.GetValue(null); // static classes cannot be instanced, so use null...
                    if (highestLevel > (int)v || highestLevel == (int)v)
                        continue;
                    highestLevel = (int)v;
                }
                return highestLevel;
            }
        }
    }

OverallStatusEnum

public enum OverallStatusEnum
        {
            Ok,
            Warning,
            Error
        }