我知道我们可以通过调用 DotNet.invokeMethodAsync 方法从 JavaScript 更改 Blazor 中的 C# 属性值。我有以下工作,但在这个方法中我也想调用一个非静态方法。
JS 文件:
[script.js]
function ChangeContentJS() {
DotNet.invokeMethodAsync('InvokeFromJsApp', "ChangeParaContentValue", "New Content");
}
剃刀页面:
[Index.razor]
@page "/"
@inject IJSRuntime JSRuntime
<h1>Change C# property value from JavaScript</h1>
<br />
<button @onclick='ButtonClickHandler'>Change Content - JS</button>
<br />
<p>@ParaContent</p>
@code {
public static string ParaContent = "Some Text Content";
public async Task ButtonClickHandler()
{
await JSRuntime.InvokeAsync<string>("ChangeContentJS");
}
[JSInvokable]
public static void ChangeParaContentValue(string value)
{
ParaContent = value;
RunNewCode(); //DOESNT WORK AS ITS A NON-STATIC METHOD
}
public void RunNewCode()
{
jsRuntime.InvokeVoidAsync("RunFunction");
}
}
我正在尝试在静态方法中运行非静态方法(在 BLAZOR 应用程序中)。如何调用此方法?
我尝试将以下方法设为静态并出现以下错误:
public static void RunNewCode()
{
jsRuntime.InvokeVoidAsync("RunFunction");
}
<块引用>
CS0120:非静态字段需要对象引用, 方法或属性 'JSRuntime'
我如何使它成为静态:@inject IJSRuntime JSRuntime
答案 0 :(得分:4)
实际上是这样描述的in the docs
夏天:
为更新创建静态 Action
并注册本地实例
private static Func<string, Task> ChangeParaContentActionAsync;
private async Task LocalChangeParaContentValueAsync(string value)
{
ParaContent = value;
await jsRuntime.InvokeVoidAsync("RunFunction");
}
protected override void OnInitialized()
{
base.OnInitialized();
ChangeParaContentActionAsync= LocalChangeParaContentValueAsync;
}
[JSInvokable]
public static async Task ChangeParaContentValue(string value)
{
await ChangeParaContentActionAsync.Invoke(value);
}
(未测试)
注意重要的是要记住,即使组件未加载(即没有实例),您仍然可以调用 JSInvokable 方法。这可能会导致未定义的行为!
编辑:更改为 async Task
,由于异步 InvokeVoidAsync
方法