我正在尝试将我的 Blazor Server 项目拆分为组件,以使其更易于管理。
我希望我的组件有一个作为参数传入的函数。该函数接受一个字符串参数,并在单击按钮时使用与组件不同的名称调用它。
我尝试了一些我在网上找到的答案,但它们似乎不起作用(如绑定事件)
代码
我有一个名为的组件ItemMenu.razor
和我的 index page Index.razor
。
ItemMenu.razor
:
<button @onclick="() => OnClickFunction.Invoke(foo)">foo</button>
<button @onclick="() => OnClickFunction.Invoke(ping)">ping</button>
@code {
[Parameter] public Action<string> OnClickFunction { get; set; }
const string foo = "bar";
const string ping = "pong";
}
Index.razor
:
@page "/"
<h1>This is my index page!</h1>
<ItemMenu OnClickFunction="ShowName" /> @*Error: No overload for 'ShowName' matches delegate 'Action'*@
@code {
public void ShowName(string myName)
{
Console.WriteLine(myName);
}
}
错误
第 3 行Index.html
抛出错误No overload for 'ShowName' matches delegate 'Action'
解决方案
原来我只需要将我的变量重命名为OnClick
而不是OnClickFunction
...
好的@enet 指出变量名不是问题。在 blazor 中,我们应该使用 EventCallback 而不是 Action。
原来在我的案例中真正的问题是 Visual Studio,因为我之前在查看其他答案时发现了这个解决方案。VS 决定在这一行显示一个错误,即使它编译并运行良好......