Blazor全局通知服务通过创建NotificationService管理通知队列并触发UI更新,配合NotificationItem组件渲染,注册为scoped服务后在任意组件中注入调用Show()方法即可显示通知。
Blazor 实现全局通知服务,核心是创建一个可被任意组件注入、跨页面共享状态的 Service,并配合一个统一的 UI 组件(如 Toast 或 Banner)来渲染通知。关键在于状态管理 + 组件通信 + 生命周期控制。
先定义一个轻量通知类,包含类型(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 更新——推荐用 EventCallback 或 Subject(配合 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();
}
}
在 Program.cs(.NET 6+)中注册为 scoped 服务:
builder.Services.AddScoped();
在 App.razor 或 MainLayout.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;
}
}
封装单条通知的样式与交互,支持手动关闭、动画入场/离场(可用 CSS transition 或第三方库如 blazored-toast):
@using System.Text.RegularExpressions
@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; }
}
哪里需要就在哪里 @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
# 的是
# 进阶
# 就在
# 自定义
# 跳转
# 第三方
# 创建一个
# 关键在于
# 最常用
# 移除
相关文章:
c++ stringstream用法详解_c++字符串与数字转换利器
建站之星安装后如何配置SEO及设计样式?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
高端云建站费用究竟需要多少预算?
如何快速搭建高效简练网站?
建站之星安装后如何自定义网站颜色与字体?
如何在自有机房高效搭建专业网站?
股票网站制作软件,网上股票怎么开户?
如何将凡科建站内容保存为本地文件?
如何设置并定期更换建站之星安全管理员密码?
高防服务器:AI智能防御DDoS攻击与数据安全保障
建站为何优先选择香港服务器?
香港服务器部署网站为何提示未备案?
如何设计高效校园网站?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
如何挑选高效建站主机与优质域名?
制作网站外包平台,自动化接单网站有哪些?
寿县云建站:智能SEO优化与多行业模板快速上线指南
建站之星如何一键生成手机站?
如何高效生成建站之星成品网站源码?
相册网站制作软件,图片上的网址怎么复制?
西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
linux top下的 minerd 木马清除方法
济南企业网站制作公司,济南社保单位网上缴费步骤?
网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
盘锦网站制作公司,盘锦大洼有多少5G网站?
如何高效利用亚马逊云主机搭建企业网站?
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
网站制作说明怎么写,简述网页设计的流程并说明原因?
如何在IIS中新建站点并配置端口与IP地址?
网站制作话术技巧,网站推广做的好怎么话术?
焦点电影公司作品,电影焦点结局是什么?
宝塔面板创建网站无法访问?如何快速排查修复?
如何在宝塔面板中创建新站点?
建站之星导航如何优化提升用户体验?
安云自助建站系统如何快速提升SEO排名?
如何在IIS7中新建站点?详细步骤解析
公司网站制作需要多少钱,找人做公司网站需要多少钱?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
如何自定义建站之星模板颜色并下载新样式?
c# await 一个已经完成的Task会发生什么
东莞专业制作网站的公司,东莞大学生网的网址是什么?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
如何通过FTP服务器快速搭建网站?
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
*请认真填写需求信息,我们会在24小时内与您取得联系。