0

0

C# 怎么在 Blazor 中进行组件间通信_C# Blazor 组件通信方法详解

煙雲

煙雲

发布时间:2025-11-12 20:02:02

|

894人浏览过

|

来源于php中文网

原创

父组件通过Parameter传值,子组件用EventCallback回调,双向绑定用@bind,跨组件通信依赖服务注入。

c# 怎么在 blazor 中进行组件间通信_c# blazor 组件通信方法详解

在 Blazor 中,组件间通信是构建模块化、可维护应用的关键。由于 Blazor 是单页应用框架,组件之间默认是独立的,因此需要明确的方式进行数据传递和方法调用。以下是几种常用的组件通信方式,适用于不同场景。

1. 父组件向子组件传递数据(通过参数)

这是最基础的通信方式。使用 [Parameter] 特性将数据从父组件传入子组件。

示例:

子组件 ChildComponent.razor:

@code {
    [Parameter] public string Message { get; set; } = string.Empty;
}

接收到的消息:@Message

父组件 ParentComponent.razor:

只要 Message 属性被标记为 [Parameter],父组件就可以通过属性绑定方式传值。

2. 子组件向父组件通知事件(通过回调委托)

子组件无法直接调用父组件的方法,但可以通过 EventCallback 实现反向通信。

子组件 ChildComponent.razor:

@code {
    [Parameter] public EventCallback OnMessageSent { get; set; }

    private async Task SendMessage() {
        await OnMessageSent.InvokeAsync("这是来自子组件的消息");
    }
}

父组件 ParentComponent.razor:

@code {
    private void HandleMessage(string msg) {
        Console.WriteLine(msg);
    }
}

这种方式实现了子组件触发、父组件响应的事件机制。

稿定AI设计
稿定AI设计

AI自动去水印、背景消除、批量抠人像工具

下载

3. 使用双向绑定(Two-way Binding)

当需要父子组件共享一个值并同步更新时,可以使用 @bind 实现双向绑定。

子组件 EditableValue.razor:

@code {
    [Parameter] public string Value { get; set; } = string.Empty;
    [Parameter] public EventCallback ValueChanged { get; set; }

    private async Task OnInput(ChangeEventArgs e) {
        if (e.Value is string input) {
            await ValueChanged.InvokeAsync(input);
        }
    }
}

父组件中使用:

redText" />
@code {
    private string sharedText = "初始值";
}

Blazor 会自动识别 Value 和 ValueChanged 配对,实现双向同步。

4. 跨层级或非父子组件通信(使用依赖注入服务)

当组件层级较深或没有直接关系时,推荐使用一个共享的服务来管理状态和通信。

定义一个状态服务:

public class MessageService {
    public string CurrentMessage { get; private set; } = string.Empty;

    public event Action? OnMessageChanged;

    public void UpdateMessage(string message) {
        CurrentMessage = message;
        OnMessageChanged?.Invoke();
    }
}

在 Program.cs 中注册服务:

builder.Services.AddSingleton();

任意组件中注入并使用:

@inject MessageService MessageService

@code {
    protected override void OnInitialized() {
        MessageService.OnMessageChanged += StateHasChanged;
    }

    private void SendMessage() {
        MessageService.UpdateMessage("新消息");
    }

    public void Dispose() {
        MessageService.OnMessageChanged -= StateHasChanged;
    }
}

这种模式类似于“发布-订阅”,适合全局状态管理,如用户登录状态、主题切换等。

基本上就这些。根据组件关系选择合适的方式:父子用 Parameter 和 EventCallback,深层或跨组件用服务注入。不复杂但容易忽略细节,比如事件注销和绑定命名规则。掌握这些,Blazor 组件通信就很清晰了。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

381

2023.08.02

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

768

2023.08.22

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

176

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

98

2025.11.27

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

468

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

13

2025.12.06

console接口是干嘛的
console接口是干嘛的

console接口是一种用于在计算机命令行或浏览器开发工具中输出信息的工具,提供了一种简单的方式来记录和查看应用程序的输出结果和调试信息。本专题为大家提供console接口相关的各种文章、以及下载和课程。

412

2023.08.08

console.log是什么
console.log是什么

console.log 是 javascript 函数,用于在浏览器控制台中输出信息,便于调试和故障排除。想了解更多console.log的相关内容,可以阅读本专题下面的文章。

501

2024.05.29

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 3万人学习

Django 教程
Django 教程

共28课时 | 3.4万人学习

React 教程
React 教程

共58课时 | 4.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号