【炫丽】从0开始做一个WPF+Blazor对话小程序(12)

  1. RazorViews\SecondView.razorOnInitialized()方法里订阅业务消息通知:
@using WPFBlazorChat.Messages<MApp><MToolbar><MTabs BackgroundColor="primary" Grow Dark><MTab><MBadge Color="pink" Dot>Item One</MBadge></MTab><MTab><MBadge Color="green" Content="tagCount">Item Two</MBadge></MTab><MTab><MBadge Color="deep-purple accent-4" Icon="mi-masa">Item Three</MBadge></MTab></MTabs></MToolbar><MRow><MButton class="mx-2" Fab Dark Large Color="purple" OnClick="ReponseMessage"><MIcon>mdi-android</MIcon></MButton></MRow></MApp>@code{private int tagCount = 6;protected override void OnInitialized(){// 订阅业务消息,在主窗口点击桃心按钮时触发Messenger.Default.Subscribe<SendRandomDataMessage>(this, msg =>{this.InvokeAsync(() => { this.tagCount = msg.Number; });this.StateHasChanged();}, ThreadOption.UiThread);}void ReponseMessage(){// 通知主窗体,我已经收到消息,请不要再发Messenger.Default.Publish(this, new ReceivedResponseMessage(this));}}注意看,上面收到消息时有两个方法要简单说一下,看OnInitialized()里的代码:
  • InvokeAsync:将Number赋值给变量tagCount的代码是在InvokeAsync方法里执行的,这个和WPF里的Dispatcher.Invoke是一个意思,相当于接收数据是在子线程,而赋值这个操作会即时的绑定到<MBadge Color="green" Content="tagCount">上,就需要UI线程同步 。
  • StateHasChanged:相当于WPF MVVM里的PropertyChanged事件通知,通知UI这里有值变化了,请你刷新一下,我要看看最新值 。
上面的代码把子窗体消息回应也贴上了,即点击安卓图标按钮时发送了ReceivedResponseMessage消息,在主窗体RazorViews\MainView.razor里也订阅了这个消息,和上面的代码类似:
...<!--确认对话框开始--><PConfirm Visible="_showComfirmDialog"Title="子窗体来回应了"Type="AlertTypes.Warning"OnCancel="() => _showComfirmDialog = false"OnOk="() => _showComfirmDialog = false">说你别没事一直发,它们烦!</PConfirm><!--确认对话框结束--></MApp>@code{... // 是否显示确认对话框bool _showComfirmDialog; protected override

经验总结扩展阅读