0

0

Blazor 怎么在JS完成时获得通知

幻夢星雲

幻夢星雲

发布时间:2025-12-25 15:12:43

|

127人浏览过

|

来源于php中文网

原创

blazor中js完成时通知c#的核心是js主动回调:用dotnetobjectreference包装c#方法传给js,js执行完后调用该引用上的[jsinvokable]方法;或js返回promise,c#用invokeasync await获取结果。

blazor 怎么在js完成时获得通知

Blazor 中 JS 完成时获得通知,核心是利用 IJSRuntime.InvokeVoidAsync 调用 JS 函数,并在 JS 里通过 .NET 对象回调(即 JS 传回结果给 C#)。关键不是“等 JS 执行完”,而是“JS 主动通知 C# 完成了”。

用 DotNetObjectReference 从 JS 回调 C# 方法

这是最常用、最可靠的方式。C# 先把一个可被 JS 调用的方法包装成 DotNetObjectReference,再传给 JS;JS 在完成操作后,直接调用这个引用上的方法,触发 C# 端逻辑。

  • C# 端:在组件中创建回调方法并生成引用

@inject IJSRuntime JSRuntime
@implements IDisposable

@code {
  private DotNetObjectReference? objRef;

  protected override void OnInitialized() {
    objRef = DotNetObjectReference.Create(this);
    JSRuntime.InvokeVoidAsync("setupJsTask", objRef);
  }

  [JSInvokable]
  public void OnJsFinished(string result) {
    Console.WriteLine($"JS 已完成,返回:{result}");
    StateHasChanged();
  }

  public void Dispose() => objRef?.Dispose();
}

  • JS 端:接收引用,执行完后调用它
// wwwroot/js/site.js

window.setupJsTask = (dotNetHelper) => {
  // 模拟异步操作(如 fetch、动画、第三方 SDK 初始化)
  setTimeout(() => {
    dotNetHelper.invokeMethodAsync('OnJsFinished', '加载成功');
  }, 1000);
};

用 Promise + InvokeAsync 获取 JS 返回值(适合简单同步/异步结果)

如果 JS 函数本身返回 Promise,C# 可直接 await 它,拿到 resolve 的值。适用于 JS 逻辑明确、不需复杂状态管理的场景。

Postme
Postme

Postme是一款强大的AI写作工具,可以帮助您快速生成高质量、原创的外贸营销文案,助您征服全球市场。

下载
  • JS 端返回 Promise

window.doSomethingAsync = () => {
  return new Promise((resolve) => {
    setTimeout(() => resolve("JS 处理完毕"), 800);
  });
};

  • C# 端 await 调用,自动等待完成

var result = await JSRuntime.InvokeAsync("doSomethingAsync");
Console.WriteLine(result); // 输出:JS 处理完毕

注意生命周期和内存泄漏

使用 DotNetObjectReference 时,必须在组件销毁时调用 Dispose(),否则 JS 会持有对 .NET 对象的强引用,导致内存泄漏。

  • 务必实现 IDisposable 并释放 objRef
  • 避免在 JS 中长期缓存 DotNetObjectReference(比如挂到 window 上)
  • 若 JS 需多次回调,确保 C# 方法是线程安全的(Blazor Server 下可能跨 SignalR 连接)

基本上就这些。核心就两条路:JS 主动回调(推荐用于复杂流程),或 C# await JS Promise(适合轻量交互)。选哪个取决于你的 JS 逻辑是否可控、是否需要中间状态、以及是否要复用回调。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

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

970

2023.08.02

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

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

186

2023.11.23

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

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

130

2025.11.27

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

763

2023.08.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

554

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

738

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6045

2023.08.17

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 10万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

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

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