Blazor:对EventCallback <T>

时间:2019-07-30 15:40:49

标签: c# asp.net-core dynamic blazor

我有一个自定义组件,其中有多个事件,每个事件都有唯一的T类型。然后JSInvokable方法是一个通用的(入口点),从那里我需要调用确切的事件函数处理程序。

这样做的时候,我需要将参数和函数处理程序转换为适当的类型。但是由于类型转换问题,我使用了动态类型。

但是尽管传递了适当的参数类型,但在运行时仍无法解决问题。

请检查抛出的屏幕截图错误:

![image] [https://user-images.githubusercontent.com/12065858/62135248-84725200-b2ff-11e9-8624-cbcae3193151.png]

Comp.razor


@using Typecasting
@using System.Threading.Tasks;
@using Newtonsoft.Json;

@inherits Base;

<input id="gencomp" type="text" />



@code {

    [Parameter]
    public EventCallback<ChangeEventArgs> ValueChange
    {
        get { return (EventCallback<ChangeEventArgs>)this.GetEvent("change"); }
        set { this.SetEvent<ChangeEventArgs>("change", value); }
    }

    [Parameter]
    public EventCallback<FocusOutEventArgs> FocusOut
    {
        get { return (EventCallback<FocusOutEventArgs>)this.GetEvent("blur"); }
        set { this.SetEvent<FocusOutEventArgs>("blur", value); }
    }

    public async Task<string> DummyCall()
    {
        // dummy async action method to show case the issue
        return await Task.Run(() => { return "data"; });
    }

    [JSInvokable]
// this is entry point 
    public override object Trigger(string eventName, string arg)
    {

        EventData data = this.DelegateList[eventName];
        var eventarg = JsonConvert.DeserializeObject(arg, data.ArgumentType);
        dynamic fn = data.Handler;
// here am getting the issue
        fn.InvokeAsync(eventarg);
        return eventarg;
    }    

}

base.cs

 public Dictionary<string, EventData> DelegateList = new Dictionary<string, EventData>();
 internal virtual void SetEvent<T>(string name, EventCallback<T> eventCallback)
        {
            if (this.DelegateList.ContainsKey(name))
            {
                this.DelegateList[name] = new EventData().Set<T>(eventCallback, typeof(T));
            }
            else
            {
                this.DelegateList.Add(name, new EventData().Set<T>(eventCallback, typeof(T)));
            }
        }

        internal  object GetEvent(string name)
        {
            if (this.DelegateList.ContainsKey(name) == false)
            {
                return null;
            }
            return this.DelegateList[name].Handler;
        }

------

EventData类

public class EventData
    {
        public object Handler { get; set; }

        public Type ArgumentType { get; set; }

        public EventData Set<T>(EventCallback<T> action, Type type)
        {
            this.Handler = action;
            this.ArgumentType = type;
            return this;
        }

    }

您可以在此处找到问题重现示例。

https://github.com/gurunathancs1991/BlazorEventhandler

动态类型的eventCallback转换是否存在问题?还有其他解决方法吗?

1 个答案:

答案 0 :(得分:1)

更改:

get { return (EventCallback<ChangeEventArgs>)this.GetEvent("change"); }

收件人:

get { return (EventCallback<ChangeEventArgs>)(object) this.GetEvent("change"); }

也许现在您不需要使用动态...

祝你好运...