【发布时间】:2021-01-30 18:22:53
【问题描述】:
我正在尝试在 Blazor 中开发一个组件,我希望它能够从 C# 类中获取其所有功能(文本、EventCallbacks 等)。像这样的:
Blazor 组件(代码隐藏):
public partial class Card : ComponentBase
{
[Parameter] public CardData CardData { get; set; }
protected async Task OnActionFiredEvent(EventCallback<object> eventCallback, object itemId)
{
if (eventCallback.HasDelegate)
await CardData.CardTitleOnClickAction.InvokeAsync(itemId);
}
}
Blazor 组件(Razor):
<!-- Card image -->
<div class="view view-cascade overlay">
<a>
<div class="mask rgba-white-slight waves-effect waves-light"></div>
</a>
</div>
<!-- Card content -->
<div class="card-body card-body-cascade text-center">
<!-- Title -->
<h4 class="card-title">
<a class="waves-effect waves-light" @onclick="@(() => OnActionFiredEvent(CardData.CardTitleOnClickAction, CardData.CardItemId))">
<strong>@CardData.CardTitle</strong>
</a>
</h4>
<!-- Subtitle -->
@if (!string.IsNullOrEmpty(CardData.CardSubTitle))
{
<h6 class="font-weight-bold indigo-text py-2">@CardData.CardSubTitle</h6>
}
<!-- Text -->
@if (!string.IsNullOrEmpty(CardData.CardText))
{
<p class="card-text">
@CardData.CardText
</p>
}
</div>
<!-- Card footer -->
<div class="card-footer text-muted text-center">
@CardData.CardFooter
</div>
CarData 类:
public class CardData
{
public object CardItemId { get; set; }
public string CardTitle { get; set; }
public string CardSubTitle { get; set; }
public string CardText { get; set; }
public string CardFooter { get; set; }
public EventCallback<object> CardTitleOnClickAction { get; set; }
}
用途:
<Card CardData="@(new CardData() {
CardTitle = "TextTitle",
CardTitleOnClickAction = EventCallBackMethod,
CardSubTitle = "TextSubTitle",
CardText = "Text"})" />
问题是在将 EventCallBack 作为类属性传递时出现以下错误: 无法将方法组“EventCallBackMethod”转换为非委托类型“EventCallback”。您是否打算调用该方法?
失败的方法本身是这样的:
protected async Task EventCallBackMethod()
{
await DoSomething();
}
知道如何解决这个问题吗?
【问题讨论】:
-
EventCallback
-
感谢@BrianParker 的评论,作为测试,我尝试了以下代码:CardTitleOnClickAction = EventCallBackMethod(1)。但现在我收到错误:无法将类型“System.Threading.Tasks.Task”隐式转换为“Microsoft.AspNetCore.Components.EventCallback
-
你能做一个简单的示例项目吗?看起来该代码应该可以工作或非常接近。