C# 如何在 Blazor WebAssembly 中调用 JavaScript 函数_C# Blazor WebAssembly JS 互操作指南

畫卷琴夢
发布: 2025-11-02 02:01:15
原创
173人浏览过
Blazor WebAssembly通过IJSRuntime实现JS互操作,需注入服务并确保脚本加载;2. 可调用全局函数或模块化JS,支持传参、返回值及对象序列化;3. 注意异步调用、错误处理与资源释放。

c# 如何在 blazor webassembly 中调用 javascript 函数_c# blazor webassembly js 互操作指南

在 Blazor WebAssembly 中调用 JavaScript 函数是实现与前端 DOM 操作、第三方 JS 库集成的关键方式。Blazor 提供了内置的 JS 互操作(JavaScript Interop)机制,让你能在 C# 代码中安全地调用 JavaScript,并支持传参和返回值。

启用 JS 互操作的基本步骤

Blazor WebAssembly 允许你在 .NET 代码中通过 IJSRuntime 接口调用 JavaScript 函数。你需要注入该服务,并确保 JS 脚本已加载。

在组件中获取 IJSRuntime 实例:

  • @inject IJSRuntime JS

然后就可以使用 JS.InvokeAsync 方法来调用全局定义的 JS 函数或直接执行脚本片段。

立即学习Java免费学习笔记(深入)”;

定义并调用简单的 JavaScript 函数

wwwroot/index.html 的 <script> 标签中定义一个 JS 函数:</script>

<script>
  window.showAlert = (message) => {
    alert(`来自 C# 的消息: ${message}`);
  };
<p>window.getScreenWidth = () => {
return window.screen.width;
};
</script></p>
登录后复制

在 Razor 组件中调用这些函数:

  • await JS.InvokeVoidAsync("showAlert", "Hello from C#");
  • var width = await JS.InvokeAsync("getScreenWidth");

InvokeVoidAsync 用于没有返回值的函数,InvokeAsync 用于有返回值的情况,T 是期望的返回类型(如 int、string、bool 或对象)。

处理复杂参数和对象传递

你可以将 C# 对象传给 JavaScript,Blazor 会自动序列化为 JSON。例如:

// C#
var person = new { Name = "张三", Age = 25 };
await JS.InvokeVoidAsync("logPerson", person);
登录后复制
// JavaScript
window.logPerson = (person) => {
  console.log(person.name, person.age); // 输出:张三 25
};
登录后复制

注意:C# 属性名会转为小驼峰格式(Name → name),除非你自定义序列化设置。

异步调用与错误处理

JS 调用是异步的,应始终使用 await 并包裹在 try-catch 中防止崩溃:

try {
  var result = await JS.InvokeAsync<string>("someFunction");
} catch (JSException ex) {
  Console.Error.WriteLine($"JS 调用失败: {ex.Message}");
}
登录后复制

常见错误包括函数未定义、脚本未加载完成、跨域限制等。确保 JS 函数挂载到 window 上且页面已完全加载后再调用。

模块化 JS 调用(推荐做法)

对于大型项目,建议将 JS 封装成模块,避免污染全局作用域

// wwwroot/js/helper.js
export function showAlert(message) {
  alert(message);
}
<p>export function readLocalStorage(key) {
return localStorage.getItem(key);
}</p>
登录后复制

在组件中动态导入模块并调用:

var module = await JS.InvokeAsync<IJSObjectReference>("import", "./js/helper.js");
await module.InvokeVoidAsync("showAlert", "模块化调用!");
var value = await module.InvokeAsync<string>("readLocalStorage", "token");
await module.DisposeAsync(); // 释放引用
登录后复制

模块化方式更清晰,支持 Tree-shaking,也便于管理生命周期。

基本上就这些。只要正确引入 IJSRuntime、定义好 JS 函数、注意异步和序列化规则,就能顺畅实现 Blazor WebAssembly 与 JavaScript 的互操作。不复杂但容易忽略细节,比如函数必须挂在 window 上或使用模块导入。

以上就是C# 如何在 Blazor WebAssembly 中调用 JavaScript 函数_C# Blazor WebAssembly JS 互操作指南的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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