全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Blazor 怎么实现一个全局通知服务

Blazor全局通知服务通过创建NotificationService管理通知队列并触发UI更新,配合NotificationItem组件渲染,注册为scoped服务后在任意组件中注入调用Show()方法即可显示通知。

Blazor 实现全局通知服务,核心是创建一个可被任意组件注入、跨页面共享状态的 Service,并配合一个统一的 UI 组件(如 Toast 或 Banner)来渲染通知。关键在于状态管理 + 组件通信 + 生命周期控制。

1. 定义通知数据模型和通知服务

先定义一个轻量通知类,包含类型(Success/Info/Error/Warning)、内容、持续时间、是否自动关闭等字段:

public class Notification
{
    public string Id { get; } = Guid.NewGuid().ToString();
    public string Message { get; set; } = string.Empty;
    public NotificationType Type { get; set; } = NotificationType.Info;
    public int DurationMs { get; set; } = 5000;
    public bool AutoDismiss { get; set; } = true;
}

public enum NotificationType
{
    Info, Success, Warning, Error
}

然后创建 NotificationService,用 List 管理队列,提供添加、移除、清空方法。注意用 INotifyPropertyChanged 或 Blazor 的 StateHasChanged() 机制触发 UI 更新——推荐用 EventCallbackSubject(配合 Rx.NET)或更简单的方式:直接暴露一个 EventCallback 委托供 UI 订阅:

public class NotificationService
{
    private readonly List _notifications = new();
    public event Action? OnNotificationsChanged;

    public IReadOnlyList Notifications => _notifications.AsReadOnly();

    public void Show(string message, NotificationType type = NotificationType.Info, int durationMs = 5000)
    {
        var notification = new Notification
        {
            Message = message,
            Type = type,
            DurationMs = durationMs
        };
        _notifications.Add(notification);
        OnNotificationsChanged?.Invoke();
        
        if (notification.AutoDismiss)
        {
            _ = Task.Delay(durationMs).ContinueWith(_ =>
            {
                Dismiss(notification.Id);
            });
        }
    }

    public void Dismiss(string id)
    {
        _notifications.RemoveAll(n => n.Id == id);
        OnNotificationsChanged?.Invoke();
    }

    public void Clear() 
    {
        _notifications.Clear();
        OnNotificationsChanged?.Invoke();
    }
}

2. 注册服务并注入到根组件

Program.cs(.NET 6+)中注册为 scoped 服务:

builder.Services.AddScoped();

App.razorMainLayout.razor 顶部注入服务,并订阅变化:

@inject NotificationService NotificationService

@if (NotificationService.Notifications.Any())
{
    
        @foreach (var notification in NotificationService.Notifications)
        {
            
        }
    
}

@code {
    private void HandleNotificationsChanged() => StateHasChanged();

    protected override void OnInitialized()
    {
        NotificationService.OnNotificationsChanged += HandleNotificationsChanged;
    }

    public void Dispose()
    {
        NotificationService.OnNotificationsChanged -= HandleNotificationsChanged;
    }
}

3. 创建可复用的通知 UI 组件(NotificationItem.razor)

封装单条通知的样式与交互,支持手动关闭、动画入场/离场(可用 CSS transition 或第三方库如 blazored-toast):

@using System.Text.RegularExpressions


    @GetIcon()
    @Notification.Message
    


@code {
    [Parameter] public Notification Notification { get; set; } = default!;
    [Parameter] public EventCallback OnDismiss { get; set; }

    private string GetCssClass() => $"notification-{Notification.Type.ToString().ToLower()}";

    private string GetIcon()
    {
        return Notification.Type switch
        {
            NotificationType.Success => "✓",
            NotificationType.Error => "✗",
            NotificationType.Warning => "⚠",
            _ => "ℹ"
        };
    }
}

CSS 示例(加到 wwwroot/css/app.css 或组件内):

.notification-container {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-width: 350px;
}

.notification {
    padding: 0.75rem 1rem;
    border-radius: 4px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    animation: slideInRight 0.3s ease-out;
    transition: opacity 0.3s, transform 0.3s;
}

.notification:not(:first-child) { margin-top: 0.25rem; }

.notification-info { background: #e3f2fd; color: #1565c0; }
.notification-success { background: #e8f5e9; color: #2e7d32; }
.notification-warning { background: #fff8e1; color: #f57c00; }
.notification-error { background: #ffebee; color: #c62828; }

.notification-close {
    background: none;
    border: none;
    font-size: 1.2rem;
    cursor: pointer;
    margin-left: auto;
    color: inherit;
    opacity: 0.7;
}

.notification-close:hover { opacity: 1; }

@keyframes slideInRight {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

4. 在任意组件中使用通知

哪里需要就在哪里 @inject NotificationService,调用 Show() 即可:

@inject NotificationService NotificationService



@code {
    private void ShowSuccess() =>
        NotificationService.Show("操作已成功!", NotificationType.Success);
}

支持异步操作后通知:

private async Task SubmitForm()
{
    try
    {
        await httpClient.PostAsJsonAsync("/api/save", model);
        NotificationService.Show("保存成功", NotificationType.Success);
    }
    catch
    {
        NotificationService.Show("保存失败,请重试", NotificationType.Error);
    }
}

基本上就这些。不复杂但容易忽略的是:服务生命周期要匹配(scoped 最常用)、UI 订阅/取消订阅要配对、避免内存泄漏(尤其用委托事件时),以及通知叠加时的 z-index 和定位控制。进阶可加队列限流、点击跳转、自定义模板、声音提示等。


# css  # js  # json  # app  # ai  # switch  # nas  # 组件渲染  # .net  # red  # 封装  # Error  # 委托  # 事件  # 异步  # transition  # ui  # 的是  # 进阶  # 就在  # 自定义  # 跳转  # 第三方  # 创建一个  # 关键在于  # 最常用  # 移除 


相关文章: 网站制作新手教程,新手建设一个网站需要注意些什么?  制作表格网站有哪些,线上表格怎么弄?  如何快速生成ASP一键建站模板并优化安全性?  如何通过免费商城建站系统源码自定义网站主题与功能?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  如何用好域名打造高点击率的自主建站?  大连网站制作公司哪家好一点,大连买房网站哪个好?  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  宝塔建站后网页无法访问如何解决?  建站之星在线客服如何快速接入解答?  如何设计高效校园网站?  网站制作话术技巧,网站推广做的好怎么话术?  如何通过西部数码建站助手快速创建专业网站?  天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?  C#如何在一个XML文件中查找并替换文本内容  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?  高端智能建站公司优选:品牌定制与SEO优化一站式服务  ,怎么用自己头像做动态表情包?  建站之星会员如何解锁更多建站功能?  如何通过WDCP绑定主域名及创建子域名站点?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  C#如何序列化对象为XML XmlSerializer用法  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  北京网站制作公司哪家好一点,北京租房网站有哪些?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  ppt制作免费网站有哪些,ppt模板免费下载网站?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  网站建设设计制作营销公司南阳,如何策划设计和建设网站?  如何确保西部建站助手FTP传输的安全性?  建站之星如何快速生成多端适配网站?  建站之星体验版:智能建站系统+响应式设计,多端适配快速建站  制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?  宝塔建站教程:一键部署配置流程与SEO优化实战指南  建站之星代理商如何保障技术支持与售后服务?  小程序网站制作需要准备什么资料,如何制作小程序?  宁波自助建站系统如何快速打造专业企业网站?  如何通过FTP服务器快速搭建网站?  建站之星后台密码遗忘?如何快速找回?  如何用美橙互联一键搭建多站合一网站?  C++如何使用std::optional?(处理可选值)  建站之星与建站宝盒如何选择最佳方案?  如何在景安服务器上快速搭建个人网站?  如何通过建站之星自助学习解决操作问题? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。