您的位置:首页 >Blazor调用JS函数方法详解
发布于2026-02-05 阅读(0)
扫一扫,手机访问
Blazor通过IJSRuntime接口实现安全高效的JS互操作,推荐异步调用;需将JS函数挂载到window,C#中注入并调用;支持参数传递、返回值处理及双向调用,注意生命周期与异常处理。

Blazor 可以通过 JS Interop(JavaScript 互操作)安全、高效地调用浏览器中的 JavaScript 函数,这是混合开发的关键能力。核心在于 IJSRuntime 接口,它提供同步和异步两种调用方式,推荐优先使用异步方法(InvokeAsync)以避免阻塞 UI 线程。
先确保 JS 函数已挂载到全局作用域(如 window),再在 Razor 组件中注入并调用:
wwwroot/index.html 或 wwwroot/js/site.js 中定义函数,例如:@inject IJSRuntime JSRuntime@code {
private async Task ShowMessage() => await JSRuntime.InvokeVoidAsync("showAlert", "Hello from Blazor!");
private async Task GetWidth() {
var width = await JSRuntime.InvokeAsync("getScreenWidth");
Console.WriteLine($"Screen width: {width}");
}
} JS Interop 支持基本类型(string、int、bool)、JSON 序列化对象(需匹配 JS 结构),以及 .NET 的 ElementReference(用于 DOM 操作):
await JSRuntime.InvokeVoidAsync("updateUser", new { name = "Alice", age = 30 });window.updateUser = (user) => console.log(user.name, user.age);string、int、bool、DateTime、object(反序列化为 Dictionary<string, object> 或强类型模型)使用 IJSInProcessRuntime(仅限 Server-Side Blazor)或更通用的 DotNetObjectReference 实现 JS 主动调用 C#:
private DotNetObjectReference<MyComponent> objRef;
protected override void OnInitialized() {
objRef = DotNetObjectReference.Create(this);
JSRuntime.InvokeVoidAsync("registerCallback", objRef);
}[JSInvokable]):[JSInvokable]
public void HandleFromJs(string data) { /* 处理逻辑 */ }JS Interop 不是万能胶,需注意生命周期、线程安全和错误处理:
OnAfterRenderAsync 或用户交互事件中),避免因 DOM 未就绪导致报错InvokeAsync,捕获 JavascriptException 等异常DotNetObjectReference:public void Dispose() => objRef?.Dispose();基本上就这些。JS Interop 不复杂但容易忽略细节,重点是保持 JS 全局函数干净、C# 调用异步化、跨端数据结构对齐。用熟之后,Blazor 和前端生态就能真正打通了。
上一篇:Golang开发邮件服务教程
下一篇:绑定手机号教程:藏书馆操作指南
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9